我想知道如何循环通过文本文件中的每一行使用Windows批处理文件和处理每行文本相继。
当前回答
使用cmd.exe和
for /F "tokens=*" %F in (file.txt) do whatever "%F" ...
仅适用于“正常”文件。对于巨大的文件,它失败得很惨。
对于大文件,你可能需要使用Powershell和类似的东西:
[IO.File]::ReadLines("file.txt") | ForEach-Object { whatever "$_" }
或者如果你有足够的内存:
foreach($line in [System.IO.File]::ReadLines("file.txt")) { whatever "$line" }
这对我来说是一个250 MB的文件,包含200多万行,其中for /F…命令行写了几千行就卡住了。
关于foreach和foreach - object的区别,请参见了解foreach和foreach - object。
(字幕:在PowerShell中逐行读取文件)
其他回答
改进第一个“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---
我需要把整条线作为一个整体来处理。以下是我发现有效的方法。
for /F "tokens=*" %%A in (myfile.txt) do [process] %%A
带有星号(*)的tokens关键字将提取整行的所有文本。如果你不加星号,它只会拉出一行中的第一个单词。我想这和空格有关。
在TechNet上的命令
如果文件路径中有空格,则需要使用usebackq。为例。
for /F "usebackq tokens=*" %%A in ("my file.txt") do [process] %%A
使用cmd.exe和
for /F "tokens=*" %F in (file.txt) do whatever "%F" ...
仅适用于“正常”文件。对于巨大的文件,它失败得很惨。
对于大文件,你可能需要使用Powershell和类似的东西:
[IO.File]::ReadLines("file.txt") | ForEach-Object { whatever "$_" }
或者如果你有足够的内存:
foreach($line in [System.IO.File]::ReadLines("file.txt")) { whatever "$line" }
这对我来说是一个250 MB的文件,包含200多万行,其中for /F…命令行写了几千行就卡住了。
关于foreach和foreach - object的区别,请参见了解foreach和foreach - object。
(字幕:在PowerShell中逐行读取文件)
在批处理文件中,您必须使用%%而不是%:(键入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。
这是我写的一个bat文件来执行文件夹中的所有SQL脚本:
REM ******************************************************************
REM Runs all *.sql scripts sorted by filename in the current folder.
REM To use integrated auth change -U <user> -P <password> to -E
REM ******************************************************************
dir /B /O:n *.sql > RunSqlScripts.tmp
for /F %%A in (RunSqlScripts.tmp) do osql -S (local) -d DEFAULT_DATABASE_NAME -U USERNAME_GOES_HERE -P PASSWORD_GOES_HERE -i %%A
del RunSqlScripts.tmp
推荐文章
- 如何使用Windows命令行更改目录
- 如何使用批处理文件写入文本文件?
- 如何在NERDTree中显示隐藏文件(以句点开始)?
- Objective-C for Windows
- “注册”一个.exe,这样你就可以从Windows中的任何命令行运行它
- Windows批处理文件的隐藏特性
- Windows递归grep命令行
- 如何创建自己的URL协议?(例如:/ /……)
- 在Windows批处理脚本中格式化日期和时间
- 映射一个网络驱动器供服务使用
- 如何在windows中使用命令提示符(cmd)列出文件。我试过在Linux中使用“ls”,但它显示一个错误?
- Windows上最好的免费c++分析器是什么?
- 如何在Windows上运行多个Python版本
- 运行计划任务的最佳方式
- Windows上Git文件的权限