FindStr工作不正确

时间:2012-03-23 08:02:02

标签: shell batch-file findstr

我制作了一段批处理代码,我认为这样可行。我在想这个代码在做什么?我有一些插件,我想测试部署是否正确。所以我从plugins.txt获得了pluginlink。然后我从SVN获得带有java句子的插件。我部署了插件并在test1.txt中获得反馈。然后我在该文件中执行findStr并搜索“BUILD SUCCESSFUL”如果它在那里我想添加句子Build Gelukt如果它失败我想添加Build Fout。但是我总是得到Build Gelukt的答案,而正如你在图像中看到的那样,他发回的是构建失败。

这段代码怎么了?

for /f "tokens=* delims= " %%a in (plugins.txt) do (
echo %%a
cd "C:\dotCMS Automatic Install"
java -cp .;"C:\dotCMS Automatic Install\svnkit.jar" Test %%a
cd %dotcms_home%
call ant deploy-plugins > test1.txt
FindStr "SUCCESSFUL" test1.txt
if %ERRORLEVEL% ==1 (echo ^<tr BGCOLOR=\"#FFFFFF\"^>^<td^>%%a^</td^>^<td^>Build Fout^</td^>^</tr^> >> C:\dotCMSResults\goedje.html ) else (echo ^<tr BGCOLOR=\"#00FF00\"^>^<td^>%%a^</td^>^<td^>Build Gelukt^</td^>^</tr^> >> C:\dotCMSResults\goedje.html) 
del test1.txt
rem call ant undeploy-plugins >> test.txt
)

enter image description here

2 个答案:

答案 0 :(得分:11)

经典批处​​理问题 - 您正在设置ERRORLEVEL并尝试在同一%ERRORLEVEL%子句中使用DO()访问它。 %VAR%扩展在解析时发生,并且整个FOR ... DO()语句被解析一次,因此在执行语句之前您将看到ERRORLEVEL的值。显然这不起作用。

杰布在他关于消失报价的评论中提到了答案。如果您setlocal enableDelayedExpansion位于顶部,则会解决您的问题,然后使用!ERRORLEVEL!代替%ERRORLEVEL%。此外,GregHNZ是正确的,因为ERRORLEVEL测试应该在FINDSTR语句之后立即发生。

还有其他方法可以在不需要延迟扩展的括号内处理ERRORLEVEL:

如果ERRORLEVEL大于或等于1

,则进行以下测试
IF ERRORLEVEL 1 (...) ELSE (...)

以下有条件地根据先前命令的结果执行命令

FindStr "SUCCESSFUL" test1.txt && (
  commands to execute if FindStr succeeded
) || (
  commands to execute if prior command failed.
)

答案 1 :(得分:2)

%ErrorLevel%变量仅适用于上一个命令。

所以当你这样做时:

echo Errorlevel: %ERRORLEVEL%

使用当前代码,您将获得上面CD命令的错误级别

尝试在if %ERRORLEVEL% ==1命令之后立即放置FindStr行,然后再执行del和cd。显然,你需要在echo语句中输入html文件的完整路径。