标题: [已解决]请教如何将命令的输出既显示又输出到log文件中?
[打印本页]
作者: sonicandy
时间: 2008-11-29 11:57
标题: [已解决]请教如何将命令的输出既显示又输出到log文件中?
比如我想使用hhc.exe生成chm文件.
hhc.exe xxx.hhp
则此编译过程会显示在cmd窗口中.
如果使用
hhc.exe xxx.hhp > log.txt
则不会在屏幕上显示,直接输出到log.txt
请问能不能让输出的信息既显示在cmd窗口中,也输出到log.txt?
(已经搜索过论坛,但是没有找到可以解决这个问题的文章.)
[
Last edited by sonicandy on 2008-11-29 at 15:01 ]
作者: sonicandy
时间: 2008-11-29 15:00
猛然想起VBS可以实现这功能,已经解决了,呵呵.
调用:
dir |cscript //nologo savelog.vbs log.txt
Set fso = CreateObject("scripting.filesystemobject")
Set stream = fso.opentextfile(wscript.arguments(0),2,true)
While Not wscript.stdin.atendofstream
line = wscript.stdin.readline
wscript.stdout.writeline(line)
Call stream.writeline(line)
Wend
Call stream.close
作者: HAT
时间: 2008-11-29 17:10
@echo off
dir>log.txt
type log.txt
pause
作者: lxmxn
时间: 2008-11-29 17:47
有个命令行工具 tee 。
作者: yishanju
时间: 2008-11-29 20:26
好像 MTEE更加强大
更好用
作者: sonicandy
时间: 2008-11-29 23:16
刚才实现了chm的生成代码,这回不用调用命令行了,直接在vbs的内部就可以完成.
vbs的wshshell提供了一个wshscriptexec对象:
http://www.elook.net.cn/handbook ... criptexecobject.htm
这个对象是通过wshell.exec得到的,以下是我实现的部分代码:
' 调用'hhc.exe'生成chm并保存输出到log文件
Sub GenChm()
Dim stream
Set stream = fso.opentextfile(logfile,2,true)
Dim oexec
Set oexec = shell.Exec(cmdline)
Do While Not oExec.StdOut.AtEndOfStream
Dim line
line = oexec.stdout.readline()
Call wscript.stdout.writeline(line)
Call stream.writeline(line)
Loop
Call stream.close
End Sub
当然,为了让wscript的标准输入输出句柄有效,必须使用cscript宿主来运行:-)
[
Last edited by sonicandy on 2008-11-29 at 23:21 ]
作者: sonicandy
时间: 2008-11-29 23:26
Quote: |
Originally posted by HAT at 2008-11-29 05:10 PM:
@echo off
dir>log.txt
type log.txt
pause |
|
这个貌似是命令执行完了以后才显示的,这样就没有即时显示的效果了.
当然如果命令运行时间不长的话可以使用这个方式:->
作者: sonicandy
时间: 2008-11-29 23:30
4版主和5楼朋友说的工具我还没有用过..
不知道实现的是不是相同的功能?
如果是的话,还是直接写个脚本方便,呵呵
[
Last edited by sonicandy on 2008-11-29 at 23:32 ]
作者: lxmxn
时间: 2008-11-30 00:55
mtee 还不错,不仅可以在每行输出前面添加时间日期,还可以把输出追加到任意多个文件。
http://www.commandline.co.uk/mtee/mtee.zip