找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 44333|回复: 8

[其他] 【已解决】批处理同时输出到控制台和文件

[复制链接]
发表于 2015-8-16 19:49:48 | 显示全部楼层 |阅读模式
本帖最后由 回家路上 于 2015-8-17 19:28 编辑

我想执行一段批处理,需要输出到文件中,又想在控制台看到。
不用第三方(mtee)的情况下,纯批处理能做到吗?
简化例子:

  1. @echo off
  2. echo;前面一堆
  3. call :somecmd

  4. ::↓↓↓↓↓↓输出到文件
  5. call echoinfo.bat
  6. ::↑↑↑↑↑↑且实时在控制台显示

  7. echo;后面面一堆
  8. call :somecmd
  9. pause & exit /b

  10. :somecmd
  11. echo;各种命令
  12. goto :eof
复制代码
echoinfo.bat:

  1. @echo off
  2. for /l %%i in (1,1,20)do (
  3.         echo;%%i==============%%i
  4.         ping -n 2 127.1 >nul
  5. )
复制代码
将输出内容同时输出到文件和控制台(控制台实时显示,文件无所谓)
用临时文件也行。
发表于 2015-8-16 21:37:25 | 显示全部楼层
  1. call echoinfo.bat >输出文件.txt
复制代码
echoinfo.bat:
  1. @echo off
  2. for /l %%i in (1,1,20)do (
  3.         echo;%%i==============%%i
  4. 1>&2    echo;%%i==============%%i
  5.         ping -n 2 127.1 >nul
  6. )
复制代码
 楼主| 发表于 2015-8-16 23:03:53 | 显示全部楼层
回复 2# CrLf


哇哦,又长知识了。输出流和错误流竟然可以这么用。
如果例子中的【echoinfo.bat】不能改,请问还有木有办法。
发表于 2015-8-16 23:17:50 | 显示全部楼层
回复 3# 回家路上


    那就用 for /f "delims=" %%a in ('call echoinfo.bat') do ...,或者其他类似思路
 楼主| 发表于 2015-8-16 23:32:32 | 显示全部楼层
回复 4# CrLf


嗯,我也有在想用for循环行不,但是将call xxx命令放在for里
  1. for /f "delims=" %%a in ('call echoinfo.bat') do ...
复制代码
这种必须等到call命令执行完,for才去解析文本,
所以我觉得行不通,我在想是否用临时文件是否能。
但没想到在一个批处理里同时写/读/分析一个文本文件怎么搞。
。。。
发表于 2015-8-16 23:41:15 | 显示全部楼层
回复 5# 回家路上


    那就没辙了
 楼主| 发表于 2015-8-17 13:40:58 | 显示全部楼层

标题

回复 6# CrLf
嗯,试了,用start也不能同时写和读文件。看来确实不行。谢啦。
发表于 2015-8-17 14:45:37 | 显示全部楼层
回复 7# 回家路上


    用 type 可以在写入的同时读文件,不过只能读到已经写入的部分

评分

参与人数 1技术 +1 收起 理由
回家路上 + 1 乐于助人

查看全部评分

 楼主| 发表于 2015-8-17 19:25:56 | 显示全部楼层
本帖最后由 回家路上 于 2015-8-18 14:14 编辑

回复 8# CrLf


嘿,果然诶。我试了试type真的可以展示文件内容。这就是我想要的。然后我转念一想,more会不会也可以呀,可以的话就更容易实现将日志输出到控制台。
一试果然可以,就做了一个DEMO。写的不好,但是行得通哈。

  1. @echo off&if not %1.==. call%*&exit
  2. :: DEMO
  3. :: 模拟调用一个外部程序,将其输出记录入日志文件同时输出到控制台。

  4. set "logfile=%~dp0log.txt"
  5. set "tmpfile=%~dp0$tmp$"
  6. ::起一个线程读文件
  7. ::↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
  8. start /b %~s0 :showinfo %logfile% %tmpfile%
  9. ::↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑

  10. if exist "%tmpfile%" del /q "%tmpfile%"
  11. if exist "%logfile%" del /q "%logfile%"
  12. for /l %%i in (3,-1,0) do ping -n 2 127.1 >nul&echo;%%i秒后开始执行并记录日志。。。

  13. ::模拟记录日志文件向文本输入文件
  14. call :writeinfo>%logfile% & cd.>%tmpfile%

  15. for /l %%i in (0,1,3) do ping -n 2 127.1 >nul&echo;完事了,再干点别的什么。
  16. pause & exit /b

  17. :showinfo
  18. set "logfile=%~1" & set "tmpfile=%~2"
  19. setlocal enabledelayedexpansion
  20. :show
  21. if exist "%~1" (
  22.         if "%idx%" lss "0" for /f %%i in ('more !logfile!^|find /c /v ""') do set "idx=%%i"
  23.         if "%idx%" geq "0" (
  24.                 for /f "delims=" %%i in ('more +%idx% !logfile!^|findstr /n .*') do (
  25.                         set info=%%i
  26.                         echo;!info:*:=!
  27.                         set /a idx+=1
  28.                 )
  29.         )
  30.         ping -n 1 127.1 >nul
  31. )
  32. if exist "!tmpfile!" (
  33.         del /q "!tmpfile!"&goto :eof
  34. )
  35. goto :show

  36. :writeinfo
  37. if 1%a% geq 130 goto :eof
  38. set /a a+=1,gap=%random%%%5
  39. echo;%a%======%gap%======%a%
  40. ping -n %gap% 127.1 >nul
  41. goto :writeinfo
复制代码
谢谢啦。O(∩_∩)O!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-18 18:18 , Processed in 0.021750 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表