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列及后面的所有列
运行结果:
领取专属 10元无门槛券
私享最新 技术干货