命令格式:for{%variable |%% variable } in (集合) do

command [options]

%variable |%% variable: 代表可替换参数。使用%variable通过命令提示符执行for命令。使用%% variable在批处理文件中执行for命令;

这个变量可以是26个英文字母任意一个,也可以是其他;这些变量会区分大小写,%%x 和%%X代表不同的变量;避免与bat的%0~%9发生冲突,最好不要定义成这个形参。

集合: 文件,目录,字符串或者范围数值的集合;可以是一个,也可以是多个,每一个字符串或变量,我们称之为一个元素,每个元素之间,用空格键、跳格键、逗号、分号或等号分隔

@echo off
for %%x in (nicky=rebecia=jady) do (
      echo %%x
)
pause

 

Command: 要执行的命令

Options: 参数选项

@echo off
for %%x in (*.txt) do (
      echo %%x content listed as follow:
      type %%x \n
)
pause

 

for /f 是以行为基本操作单位的,类似于Linux awk命令

 

二、切分字符串的利器:delims=x

rem 以:做为分隔符,且取得:之前的数据,后面的数据不见了。

for /f "delims=:" %%i in (1.txt) do

@echo off
for /f "delims=:" %%i in (1.txt) do (
      echo %%i
)
pause

如果不指定,默认是以空格或者tab作为分割的。

你也可以一次性指定多个分割符号,即所谓的符号列表,这样只要满足符号列表的数据,都会把符号前面的数据提取出来

语法:for /f"delims=,.: " %%i in (1.txt) do 四个符号作为分割

 

三、定点提取:tokens= 数字 指定第几个token输出

Tokens后面一般跟数字,可以是多个数字,但是每一个数字之间用逗号分开,如tokens=3,5,7 含义是:提取第3,5,8节字符串

for /f "delims=: tokens=2" %%i in (1.txt)do

1.txt 内容如下:

A:B:C:D:E
AA:BB:CC:DD
AAA;BBB;CCC;DDD
AAAA,BBBB,CCCC,DDDD

 

@echo off
for /f "delims=,;: tokens=1" %%i in (1.txt) do (
      echo %%i
)
Pause
Results:
A
AA
AAA
AAAA

既然如此,那么我指定多个tokens, 怎么接收呢?

可以再指定一个变量,来接受第二个token,语法如下:

for /f "delims=,;: tokens=1,2" %%i in(1.txt) do

其中tokens=1,N 也可以表示为tokens=1-N,那么之间连续的数都会被使用:

 

@echo off
for /f "delims=,;: tokens=1,2" %%i in (1.txt) do (
      echo %%i %%j
)
Pause
结果:
A B
AA BB
AAA BBB
AAAA BBBB

 

四:跳过无关内容:skip=n 跳过无关的行,从N+1行开始处理

@echo off
for /f "skip=1 delims=,;: tokens=1,2" %%i in (1.txt) do (
      echo %%i %%j
)
Pause
结果:
AA BB
AAA BBB
AAAA BBBB

把第一行给去掉了

五、忽略指定字符开头的行 eol=

语法格式:for /f"eol=A,B delims=,;: tokens=1,2" %%i in (1.txt) do

忽略以A和B开始的行

@echo off
for /f "eol=A,B delims=,;: tokens=1,2" %%i in (1.txt) do (
      echo %%i %%j
)
pause

 

六:集合中语法

6.1 如果集合是读取文件作为内容:

for –f %%x in (*.txt) do

6.2 如果集合是命令执行结果,圆括号内容需要用单引号括起来:

for –f %%x in ('dir /a-d /b *test*.txt') do

6.2 如果集合是字符串,应该用双引号括起来:

for –f %%x in ("AA.BB,CC,DD") do

 

七:usebackq 增强性质的参数,那么for语句第一个括号内的写法有所改变,即集合的写法有所改变,怎么改变?

7.1 如果以前是用单引号括起来的命令结果作为参数,那么单引号改为后引号``;

for –f %%x in (·dir /a-d /b *test*.txt·) do

7.2 如果之前是字符串的话,那么双引号改为单引号

for –f %%x in (‘AA.BB,CC,DD’) do

7.3 如果是文件名的话,就需要用双引号括起来

for –f %%x in (“*.txt”) do

我们还必须要注意一件事情,就是路径问题:如果路径包含特殊符号我们需要用双引号把路径括起来

八:变量延迟和扩展

例子:

@echo off

set var=nicky && echo %var%

pause

显示结果echo is off

@echo off
set var=nicky
if %var%==nicky (
    set var=belly
    echo %var%
)

一般新手会认为var是belly,但其结果显示的是nicky

为什么呢?这就和变量延迟有关系了。

windows在解释执行此代码段时,在遇到if,for语句后的括号后,只把它当一条语句处理而不是两条语句,那么既然如此,那么在if语句内的var变量虽然被赋值了,但是这条语句相当于只是做了预处理,并没有真正影响到执行时的var值。即这条语句还没有被执行,那怎样才会得到想要结果呢,首先容易想到的是在if语句后面去输出var值。

方法一:

@echo off
set var=nicky

if %var%==nicky (
    set var=belly
)
echo %var%
pause
结果:belly

方法二:开启变量延迟

setlocal enabledelayedexpansion用于开启变量延迟

告诉解释器,在遇到复合语句的时候,不要将其作为一条语句同时处理,而仍然一条一条地去解释。但是这时必须用!var!来引用变量,如果仍然用%var%引用是无效的

@echo off
setlocal enabledelayedexpansion
set var=nicky

if %var%==nicky (
    set var=belly
      echo !var!
)
Pause
结果:belly

 

开启变量延迟之前的变量和之后的变量的值包含感叹号,是有一点区别的

@echo off
setlocal enabledelayedexpansion
set var=nicky

if %var%==nicky (
    set var=belly!
      echo !var!
)
Pause
结果还是belly,不是belly!,windows给去掉了

应对这种办法只有暂时关闭延迟了,或者在延迟之前set 变量的值

@echo off
set var=nicky
if %var%==nicky (
    set var=belly!
      setlocal enabledelayedexpansion
      echo !var!
)
pause

十:FOR /L%variable IN (start,step,end) DO command [command-parameters]

@echo off
for /L %%x in (2,2,10) do echo %%x
pause
result:
2
4
6
8
10

十一:FOR /D%variable IN (set) DO command [command-parameters]

如果Set (也就是我上面写的"相关文件或命令")包含通配符(*和?),将对与Set相匹配的每个目录(而不是指定目录中的文件组)执行指定的Command。

@echo off
::列举出包含e和i的目录
for /D %%a in (*e* *i*) do echo %%a
pause
结果:
Cache
deploy
LogsAndDiagnostics

 

十二:递归FOR /R[[drive:]path] %variable IN (set) DO command [command-parameters]

进入根目录树[Drive:]Path,在树的每个目录中执行for语句。如果在/R后没有指定目录,则认为是当前目录。如果Set只是一个句点(.),则只枚举目录树。

@echo off


rem 遍历当前目录下所有文件

for /r %%x in (*) do (echo %%x) 

pause