for/F命令详解

本文详细介绍了Windows批处理中FOR /F命令的使用方法,包括命令格式、参数说明及具体应用场景。通过实例演示了如何处理文件内容、字符串和命令输出结果,展示了delims、tokens等选项的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、概述

for命令开关有很多,/L,/F,/R。这里仅对含有/F的for进行分析,这个可能是最常用的,也是最强的命令,主要用来处理文件和一些命令的输出结果。

1.命令格式:
(1).FOR /F ["options"] %%i IN (file) DO command
(2).FOR /F ["options"] %%i IN ("string") DO command--注意双引号
(3).FOR /F ["options"] %%i IN ('command') DO command--注意单引号

 

2.参数说明:

file代表一个或多个文件,可以使用通配符。
string 代表字符串
command代表命令
["options"]选项有多个:

 eol=c           - 指定一个行注释字符,遇到c开头的行就忽略掉。
 skip=n          - 指定在文件开始时忽略的行数。
 delims=xxx      - 指定分隔符。默认是空格和TAB

 tokens=x,y,m-n  - 指每行的哪一个符号被传递到每个迭代
                   的 for 本身。这会导致额外变量名称的分配。m-n
                   格式为一个范围。通过 nth 符号指定 mth。如果
                   符号字符串中的最后一个字符星号,
                   那么额外的变量将在最后一个符号解析之后
                   分配并接受行的保留文本。
 usebackq        - 1.把单引号字符串作为命令;2.允许中使用双引号扩起文件名称。

二、详细介绍
1.FOR /F %%i IN (file) DO command
    file为文件名,按照官方的说法是,for会依次将file中的文件打开,并且在进行到下一个文件之前将每个文件读取到内存,按照每一行为一个元素,忽略空白的行。
    假如文件d:\out.txt中有如下内容:

  第1行第1列第1行第2列第1行第3列
  第2行第1列第2行第2列第2行第3列
  第3行第1列第3行第2列第3行第3列

怎么遍历文件中的内容呢?下面的语句可以:
for /f %%i in (d:\out.txt) do echo %%i


执行过程:for会先打开out.txt,然后读出out.txt里面的所有内容,把它作为一个集合,并且以每一行(文件中无分隔符情况下)作为一个元素,用%%i依次代替每个元素,然后执行do后面的命令。


for /f会默认以每一行(无分隔符)来作为一个元素,但是有分隔符怎么办?假如out.txt内容变成如下:

  第1行第1列 第1行第2列 第1行第3列
  第2行第1列 第2行第2列 第2行第3列
  第3行第1列 第3行第2列 第3行第3列

那么for /f %%i in (d:\out.txt) do echo %%i就无法将所有的内容显示出来。显示结果如下:

  第1行第1列
  第2行第1列
  第3行第1列

因为命令默认是以空格和TAB为分隔符,所以它遇到分割符之后,默认只取第一个,就将分割符后面的都丢掉了。

如果我们还想把每一行再分解更小的内容,该怎么办呢?for命令提供了更多的参数,它们就是:delims和tokens
delims :告诉for每一行应该拿什么作为分隔符,默认的分隔符是空格和tab键
比如,我们执行下面的命令:

for /f "delims= " %%i in (d:\out.txt) do echo %%i

显示的结果:

第1行第1列
第2行第1列
第3行第1列

这个命令和for /f %%i in (d:\out.txt) do echo %%i的效果是一样的。

 

如果我们想要每一行的后面的元素,那又如何呢?这个时候就可以利用tokens参数,它的作用就是当你通过delims将每一行分为更小的元素时,由tokens来控制要取哪一个或哪几个。
还是上面的例子,执行如下命令:

for /f "tokens=2 delims= " %%i in (d:\out.txt) do echo %%i

执行结果:

第1行第2列
第2行第2列
第3行第2列
如果要显示第二列和第三列,则换成tokens=2,3或tokens=2-3,全部显示则使用通配符tokens=*。


注意:如果显示多个元素(非*),比如这里的tokens=2-3,语句应该写成这样:

for /f "tokens=2,3 delims= " %%i in (d:\out.txt) do echo %%i %%j

怎么多出一个%%j?
这是因为你的tokens后面要取每一行的两列,用%%i来替换第二列,用%%j来替换第三列。
并且必须是按照英文字母顺序排列的,%%j不能换成%%k,因为i后面是j。
执行结果为:

第1行第2列 第1行第3列
第2行第2列 第2行第3列
第3行第2列 第3行第3列


又如下面语句:

for /f "tokens=2,* delims= " %%i in (d:\out.txt) do echo %%i %%j
它显示从第二列到最后的一列,执行结果为:

第1行第2列 第1行第3列
第2行第2列 第2行第3列
第3行第2列 第3行第3列

用%%i代替第二列,用%%j代替剩余的所有。


最后还有skip,eol和usebackq。

skip就是要忽略文件的前多少行,eol用来指定当一行以什么符号开始时,就忽略它。比如:

for /f "skip=2 tokens=*" %%i in (d:\out.txt) do echo %%i
结果为:

第3行第1列 第3行第2列 第3行第3列
用skip来告诉for跳过前两行。

 

再如,当out.txt内容变成:

#第1行第1列 第1行第2列 第1行第3列
#第2行第1列 第2行第2列 第2行第3列
第3行第1列 第3行第2列 第3行第3列

for /f "eol=# tokens=*" %%i in (d:\out.txt) do echo %%i

结果是:

第3行第1列 第3行第2列 第3行第3列
用eol来告诉for忽略以“.”开头的行。

 

usebackq就是反转的意思,他把字符串("out.txt")当做文件,或者把命令('command')当做字符串。

例如:

for /f "usebackq eol=# tokens=*" %%i in ("d:\out.txt") do echo %%i

结果是:

第3行第1列 第3行第2列 第3行第3列

如果不加usebackq,则"d:\out.txt"会被当成字符串。

又例如:

for /f "usebackq tokens=*" %%i in ('echo helloworld!') do echo %%i

结果:

echo helloworld,这里命令被当成了字符串。

如果没有usebackq

for /f "tokens=*" %%i in ('echo helloworld!') do echo %%i

结果:

helloworld!

2.FOR /F ["options"] %%i IN ("string") DO command

例子:

for /f "tokens=2,* delims= " %%i in ("this is an example!") do echo %%i %%j

结果:

is an example!

对于字符串的处理类似于文件的处理,此处不再赘述。

3.FOR /F ["options"] %%i IN ('command') DO command

 该命令将command的执行结果作为集合,后面的处理类似文件处理,此处不再赘述。

转载自:http://blog.sina.com.cn/s/blog_62defbef0101outj.html

转载于:https://www.cnblogs.com/hinata-sen/p/7443007.html

### Windows 批处理中的 `for /f` 命令详解 #### 一、基础概念 `for /f` 是一种用于解析文件或字符串并迭代其每一行的命令。该命令可以读取文本文件的内容,并逐行处理这些内容,通常与其他命令组合使用来完成复杂的脚本编写任务[^1]。 #### 二、语法结构 通用格式如下: ```batch FOR /F ["options"] %variable IN (set) DO command [command-parameters] ``` 其中,“options”部分定义如何分割每行数据;“%variable”表示用来存储每次循环得到的数据项;“(set)”指定了要遍历的目标集合,它可以是一个文件名或其他形式的数据源;最后,“DO command [command-parameters]”则是针对每一个提取出来的项目所执行的操作[^2]。 #### 三、选项参数说明 常见的 "options" 参数有以下几个重要组成部分: - `"tokens=n"`:指定想要获取的是哪几列,默认情况下只返回第一列。 - `"delims=xxx"`:设置分隔符列表,比如逗号(,)、空格()等,默认为空白字符作为分隔符。 - `"skip=n"`:跳过前面 n 行不作处理。 - `"usebackq"`:允许使用反引号(`),使得可以在双引号内包含路径中含有空格的情况下的文件名称[^3]。 #### 四、具体实例分析 下面给出几个具体的例子帮助理解上述知识点的应用场景: ##### 示例 1:简单读取文件内容 假设 tmplist.txt 文件中有若干条记录,现在希望将其打印出来: ```batch @echo off for /f "delims=" %%i in (tmplist.txt) do echo %%i pause ``` 这里设置了 `delims=` 来取消默认的空白字符分隔方式,从而确保整个行被当作单一单元传递给变量 `%%i` 进行输出。 ##### 示例 2:按特定字段抽取信息 如果有一个 CSV 格式的日志文件 log.csv ,里面包含了日期时间戳和其他一些属性值,那么可以通过设定合适的 tokens 和 delims 实现仅提取某些感兴趣的字段: ```batch @echo off for /f "tokens=1,2 delims=," %%a in (log.csv) do ( echo Date/Time: %%a - Event Code: %%b ) pause ``` 这段代码会依次取出 csv 文件里的前两列分别赋值给 `%%a` 和 `%%b` 并显示它们代表的时间戳和事件编号。 ##### 示例 3:结合其他命令过滤结果 当需要基于一定条件筛选出符合条件的日志条目时,则可进一步利用管道操作符 (`|`) 或者重定向符号 (`>`, `<`) 将外部工具的结果引入到 for 循环当中来进行更精细的信息挖掘工作。 ```batch @echo off findstr /C:"ERROR" application.log | for /f "tokens=* delims=]" %%g in ('more') do @echo Error Message Found: %%g pause ``` 在这个案例中,先通过 findstr 查找含有 ERROR 关键字的日志行,再经由 more 工具配合 for/f 对匹配上的各行做最终呈现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值