我想知道如何循环通过文本文件中的每一行使用Windows批处理文件和处理每行文本相继。
当前回答
在批处理文件中,您必须使用%%而不是%:(键入help for)
for /F "tokens=1,2,3" %%i in (myfile.txt) do call :process %%i %%j %%k
goto thenextstep
:process
set VAR1=%1
set VAR2=%2
set VAR3=%3
COMMANDS TO PROCESS INFORMATION
goto :EOF
它的作用: for命令末尾的“do call:process %%i %%j %%k”将for命令从myfile.txt中获取的信息传递给“process”“子例程”。
当您在批处理程序中使用for命令时,您需要为变量使用双%符号。
下面几行将这些变量从for命令传递给进程“子例程”,并允许您处理这些信息。
set VAR1=%1
set VAR2=%2
set VAR3=%3
我有一些非常高级的使用这个确切的设置,如果需要更多的例子,我愿意分享。当然,根据需要添加您的EOL或Delims。
其他回答
@ kraus先生的回答很有启发性。另外,如果您想加载与批处理文件位于同一目录中的文件,请在文件名前加上%~dp0。这里有一个例子:
cd /d %~dp0
for /F "tokens=*" %%A in (myfile.txt) do [process] %%A
注意:如果你的文件名或目录(例如上面例子中的myfile.txt)有一个空格(例如:'my file.txt'或'c:\程序文件'),使用:
for /F "tokens=*" %%A in ('type "my file.txt"') do [process] %%A
,使用type关键字调用type程序,该程序显示文本文件的内容。如果您不想承受调用type命令的开销,您应该将目录更改为文本文件的目录。注意,带空格的文件名仍然需要type。
我希望这能帮助到一些人!
在批处理文件中,您必须使用%%而不是%:(键入help for)
for /F "tokens=1,2,3" %%i in (myfile.txt) do call :process %%i %%j %%k
goto thenextstep
:process
set VAR1=%1
set VAR2=%2
set VAR3=%3
COMMANDS TO PROCESS INFORMATION
goto :EOF
它的作用: for命令末尾的“do call:process %%i %%j %%k”将for命令从myfile.txt中获取的信息传递给“process”“子例程”。
当您在批处理程序中使用for命令时,您需要为变量使用双%符号。
下面几行将这些变量从for命令传递给进程“子例程”,并允许您处理这些信息。
set VAR1=%1
set VAR2=%2
set VAR3=%3
我有一些非常高级的使用这个确切的设置,如果需要更多的例子,我愿意分享。当然,根据需要添加您的EOL或Delims。
改进第一个“FOR /F..”的答案: 我要做的是调用执行MyList.txt中列出的每个脚本,所以它对我有用:
for /F "tokens=*" %A in (MyList.txt) do CALL %A ARG1
——或者,如果你想在多行上做:
for /F "tokens=*" %A in (MuList.txt) do (
ECHO Processing %A....
CALL %A ARG1
)
编辑:上面给出的例子是从命令提示符执行for循环;在批处理脚本中,需要添加一个额外的%,如下所示:
---START of MyScript.bat---
@echo off
for /F "tokens=*" %%A in ( MyList.TXT) do (
ECHO Processing %%A....
CALL %%A ARG1
)
@echo on
;---END of MyScript.bat---
从命令行打印文本文件中的所有行(使用delayeexpansion):
set input="path/to/file.txt"
for /f "tokens=* delims=[" %i in ('type "%input%" ^| find /v /n ""') do (
set a=%i
set a=!a:*]=]!
echo:!a:~1!)
适用于前导空白、空行、空白行。
在win10 CMD上测试
公认的答案是好的,但有两个局限性。 它删除空行和以;
要读取任何内容的行,您需要延迟展开切换技术。
@echo off
SETLOCAL DisableDelayedExpansion
FOR /F "usebackq delims=" %%a in (`"findstr /n ^^ text.txt"`) do (
set "var=%%a"
SETLOCAL EnableDelayedExpansion
set "var=!var:*:=!"
echo(!var!
ENDLOCAL
)
Findstr用于用行号和冒号作为每行的前缀,因此空行不再是空的。
delayeexpansion需要被禁用,当访问%%a参数时,否则是感叹号!插入符号^将丢失,因为它们在该模式中具有特殊含义。
但是要从行中删除行号,需要启用延迟扩展。 设置"var=!var:*:=!"删除第一个冒号之前的所有冒号(使用delims=:也会删除一行开头的所有冒号,而不仅仅是findstr中的冒号)。 endlocal对下一行再次禁用延迟扩展。
唯一的限制现在是线长限制~8191,但似乎没有办法克服这一点。
推荐文章
- 如何验证批处理文件中是否存在一个文件?
- 如何循环通过文件匹配通配符在批处理文件
- 异步运行Windows批处理文件命令
- XAMPP -端口80被PID 4的“无法打开进程”使用!12
- 为什么git在Windows下记不住我的密码
- Git克隆/拉不断冻结在“存储密钥在缓存?”
- 如何在批处理文件中请求管理员访问
- 有没有替换Windows (Visual C)的unistd.h ?
- 从Windows批处理文件设置系统环境变量?
- 在批处理文件中处理子字符串的最佳方法是什么?
- 在Sublime Text 2中使用Ctrl+D进行多个选择时,我如何跳过匹配?
- #定义WIN32_LEAN_AND_MEAN具体排除了什么?
- 如何添加一个设置路径只执行批处理文件?
- 最好的轻量级web服务器(只有静态内容)的Windows
- npm犯错!错误:EPERM:操作不允许,重命名