好吧,我一直在玩这个,但无法让它为每个参数运行命令。
批处理文件运行方式
test.bat /r /a /c
完整批号
@echo on
SETLOCAL ENABLEEXTENSIONS
SETLOCAL ENABLEDELAYEDEXPANSION
:checkloop
set argtoken=1
FOR /F "Tokens=* delims=" %%G IN ("%*") DO (call :argcheck %%G)
pause
GOTO:END
:argcheck
if /i "%1"=="/r" set windows=1
if /i "%1"=="/a" set active=1
goto:eof
:end
"%*"显示所有参数,例如
/r /a /c
但出于某种原因,无论我尝试什么,我都无法让 for 循环分解不同的参数并为每个参数运行 :argcheck
。
更新: 对于任何对这里感兴趣的人来说,我最终得到的是什么。我在几个不同的脚本中实现它并且它的工作非常棒。只需将它放在带有调用函数和“%*”的脚本中的某处,就可以了。 :) 如果您有任何问题,请发帖。
@echo off
SETLOCAL ENABLEEXTENSIONS
SETLOCAL ENABLEDELAYEDEXPANSION
call:ArgumentCheck %*
echo %DebugMode%
echo %RestartAfterInstall%
pause
goto:eof
:ArgumentCheck
if "%~1" NEQ "" (
if /i "%1"=="/r" SET DebugMode=Yes & GOTO:ArgumentCheck_Shift
if /i "%1"=="/a" SET RestartAfterInstall=Yes & GOTO:ArgumentCheck_Shift
SET ArgumentCheck_Help=Yes
:ArgumentCheck_Shift
SHIFT
goto :ArgumentCheck
)
If "%ArgumentCheck_Help%"=="Yes" (
Echo An invalid argument has been passed, currently this script only supports
ECHO /r /a arguments. The script will continue with the arguments
ECHO you passed that is supported.
)
GOTO:EOF
:end
最佳答案
原因是 FOR/F 会将一行分成固定数量的标记,命名为 %%A,%%B,%%...(%%A 是这里的第一个命名标记)。
但是当你使用空的 delims=
时,即使这样也行不通。
FOR /F "tokens=1-5 delims= " %%A in ("%*") do (
echo %%A, %%B, %%C, %%D, %%E
)
这会把你的行分割成标记,但它甚至会像
这样分割标记One "two and three"
输出:
One, "two, and, three",
使用 SHIFT
和循环更容易。
:loop
if "%~1" NEQ "" (
call :argcheck
SHIFT
goto :loop
)
关于windows - 批处理脚本循环以检查多个参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11153339/