我想知道如何循环通过文本文件中的每一行使用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中逐行读取文件)
其他回答
修改示例在这里列出我们的Rails应用程序在Heroku -谢谢!
cmd /C "heroku list > heroku_apps.txt"
find /v "=" heroku_apps.txt | find /v ".TXT" | findstr /r /v /c:"^$" > heroku_apps_list.txt
for /F "tokens=1" %%i in (heroku_apps_list.txt) do heroku run bundle show rails --app %%i
完整代码在这里。
如果你有NT-family的Windows(使用cmd.exe作为shell),试试FOR /F命令。
从命令行打印文本文件中的所有行(使用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上测试
我需要把整条线作为一个整体来处理。以下是我发现有效的方法。
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
或者,你可以排除引号中的选项:
FOR /F %%i IN (myfile.txt) DO ECHO %%i
推荐文章
- 在Windows批处理脚本中格式化日期和时间
- 映射一个网络驱动器供服务使用
- 如何在windows中使用命令提示符(cmd)列出文件。我试过在Linux中使用“ls”,但它显示一个错误?
- Windows上最好的免费c++分析器是什么?
- 如何在Windows上运行多个Python版本
- 运行计划任务的最佳方式
- Windows上Git文件的权限
- 如何同时安装Python 2。3. Python。Windows下的x
- BAT文件执行后保持CMD打开
- 可能改变安卓虚拟设备保存的地方?
- 如何检查DLL依赖关系?
- Android-Facebook应用程序的键散列
- 如何在PowerShell中输出一些东西
- 如何在命令提示符中使用空格?
- 在Python中如何在Linux和Windows中使用“/”(目录分隔符)?