Board logo

标题: [已解决]请教如何将命令的输出既显示又输出到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