如何调试 .BAT 脚本?
-
03-07-2019 - |
题
有没有办法单步执行 .bat 脚本?问题是,我有一个构建脚本,它调用很多其他脚本,我想看看它们的调用顺序是什么,这样我就可以知道我到底应该去哪里并添加我的修改。
解决方案
我无论如何都不知道如何逐步执行.bat文件,但您可以使用 echo
和 pause
来帮助调试。
<强> ECHO 强>结果 将在批处理文件中回显消息。如ECHO Hello World将在执行时在屏幕上打印Hello World。但是,如果批处理文件开头没有@ECHO OFF,你也会得到“ECHO Hello World”。和“Hello World”。最后,如果您只想创建一个空行,请键入ECHO。在末尾添加句点会创建一个空行。
暂停强>结果 提示用户按任意键继续。
来源:批处理文件帮助
@ workmad3:answer有更多使用 echo
命令的好建议。
另一个有用的资源... DDB:DOS批处理文件提示
其他提示
确保脚本中没有'echo off'语句,并在调用每个脚本以重置您错过的任何内容后调用'echo on'。
原因是如果保持echo,则命令解释器将在执行之前输出每个命令(在参数处理之后)。使其在生产中使用看起来非常糟糕,但对于调试目的非常有用,因为您可以看到输出出错的地方。
此外,请确保您正在检查被调用的批处理脚本和程序设置的ErrorLevels。请记住,.bat文件中使用了两种不同的方法。如果您调用了一个程序,则错误级别为%ERRORLEVEL%,而从批处理文件中,错误级别在ErrorLevel变量中返回,并且不需要%s。
我发现'跑步'(win32)软件完全符合我的要求: http://www.steppingsoftware.com/
您可以加载bat文件,在查看输出和环境变量时放置断点/开始单步执行。
评估版只允许跨越50行...有没有人有类似功能的免费替代品?
退出@ECHO OFF 并调用批处理文件将所有输出重定向到日志文件..
C:GT; yourbatch.bat(可选参数)&gt; yourlogfile.txt 2&gt;&amp; 1
发现于 http://www.robvanderwoude.com/battech_debugging.php
IT工作!!不要忘记2&gt;&amp; 1 ...
WIZ
我能想到的唯一方法是使用 echo
s和 pause
s代码闪烁。
您是否尝试将结果重新路由到文件?喜欢whatever.bat&gt; log.txt
您必须确保在这种情况下,每个其他被调用的脚本也会记录到文件,例如&gt;&gt; log.txt
此外,如果您在该批处理文件的开头和结尾放置日期/ T和时间/ T,您将获得该时间点的时间,并且您可以映射脚本的运行时间和顺序。
或者.... 从另一个.bat文件中调用主.bat文件,并将结果输出到结果文件,即
runner.bat&gt; mainresults.txt
其中runner.bat调用主.bat文件
您应该会看到现在主.bat文件中执行的所有操作
或者,打开一个cmd窗口,然后从那里调用批处理,输出将显示在屏幕上。