FindStr工作不正确

Dan*_*ans 3 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
)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

dbe*_*ham 11

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

杰布在他关于消失报价的评论中提到了答案.如果你setlocal enableDelayedExpansion在顶部,你的问题将被修复,然后使用!ERRORLEVEL!而不是%ERRORLEVEL%.此外,GregHNZ是正确的,因为ERRORLEVEL测试应该在FINDSTR语句之后立即发生.

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

如果ERRORLEVEL大于或等于1,则进行以下测试

IF ERRORLEVEL 1 (...) ELSE (...)
Run Code Online (Sandbox Code Playgroud)

并且下面有条件地执行基于先前命令的结果的命令

FindStr "SUCCESSFUL" test1.txt && (
  commands to execute if FindStr succeeded
) || (
  commands to execute if prior command failed.
)
Run Code Online (Sandbox Code Playgroud)