首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Bat批处理脚本for/F语句扩展详解

for /F 扩展,功能强大,可以解析文本、切分字符串、定点提取、跳过无关内容、忽略以指定字符开头的行等等,主要用来处理文件和一些命令的输出结果。

1. for /F 基本用法

语法格式:

file-set 为一个或多个文件名。

options 可选参数,包括一个或多个指定不同解析选项的关键字,这些关键字包括eol=c、skip=n、delims=xxx、tokens=x,y,m-n、usebackq,后面将一一介绍。

先来看一个简单的实例:解析test.txt文本中的内容

运行结果:

for语句的流程是依次处理每个元素,直到所有的元素都被处理为止。在for /F语句中,,也就是说。

2. for /F 的高级选项

for /F 可以通过设置“options”关键字来实现很多高级功能。

eol=c  忽略以指定字符开头的行,可以使用该功能跳过注释,1次只能制定1个字符。

实例:通过eol=#,忽略以#开头的行。

运行结果:

可以看到test.txt文件中以#开头第二行被过滤掉了。

skip=n  指在文件开始时忽略的行数,即从文件第一行开始跳过n行,从n+1行开始显示,n是一个正整数,表示要跳过的行数。

实例:跳过前2行,从第3行显示test.txt中的信息。

运行结果:

delims=xxx  指分隔符集。这个替换了空格和制表符的默认分隔符集,意思就是可以指定多个符号进行文本分隔。

实例:通过"delims=:"将test.txt的内容进行分隔

运行结果:

delims还可以同时指定多个分隔符,当多个分隔符中有空格的时候,需要。实例:通过"delims=:. "分隔test.txt的内容。

运行结果:

可以看到:.|和空格之后的内容全部都过滤掉了。

tokens=x,y,m-n  定点提取,tokens=后面可以是一个数字或者多个数字,多个数字用英文逗号隔开,来提取通过delims分隔的列内容;

tokens=x 表示提取第x列;

tokens=x,y 表示提取第x列和第y列;

tokens=m-n 表示提取第m列到第n列;

tokens=x,y,m-n 表示提取第x列,第y列,第m列到第n列。

tokens=x* 表示提取x列后的所有字符,星号表示剩余的字符;

实例:通过“delims=|”分隔test.txt,提取分隔后的第2列;

运行结果:

“delims=|”将test.txt文本的第二行内容分隔成了8段,可以理解成8列,然后通过tokens=2提取其中的第2列。

"tokens="后面指定多个数字的时候,每一个数字截取的内容都需要一个变量来接收,比如“tokens=1,3,5”就需要3个变量接收,假如第一个变量为%%i,第二个就是%%j,第三个为%%k,变量遵循字母排序,也就是说第一个变量为a%的话,第二个必须为b%,不能是其他字母。

实例:通过“delims=|”分隔test.txt,提取分隔后的第2列,第3列,第6到8列;

运行结果:

实例:通过“tokens=3*”提取test.txt中第二行的第3列及后面的所有列

运行结果:

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20230422A0795400?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券