批处理命令For循环命令详解!
批处理命令For循环命令详解!批处理for命令详解
FOR这条命令基本上都被⽤来处理⽂本,但还有其他⼀些好⽤的功能!
看看他的基本格式(这⾥我引⽤的是批处理中的格式,直接在命令⾏只需要⼀个%号)
FOR 参数 %%变量名 IN (相关⽂件或命令) DO 执⾏的命令
参数:FOR有4个参数 /d /l /r /f 他们的作⽤我在下⾯⽤例⼦解释
%%变量名 :这个变量名可以是⼩写a-z或者⼤写A-Z,他们区分⼤⼩写,FOR会把每个读取到的值给他;
IN:命令的格式,照写就是了;
(相关⽂件或命令) :FOR要把什么东西读取然后赋值给变量,看下⾯的例⼦
do:命令的格式,照写就是了!
执⾏的命令:对每个变量的值要执⾏什么操作就写在这.
可以在CMD输⼊for /?看系统提供的帮助!对照⼀下
FOR %%variable IN (set) DO command [command-parameters]
%%variable  指定⼀个单⼀字母可替换的参数。
(set)    指定⼀个或⼀组⽂件。可以使⽤通配符。
command 指定对每个⽂件执⾏的命令。
command-parameters
为特定命令指定参数或命令⾏开关。
现在开始讲每个参数的意思
/d
仅为⽬录
如果 Set (也就是我上⾯写的 "相关⽂件或命令") 包含通配符(* 和 ?),将对与 Set 相匹配的每个⽬
录(⽽不是指定⽬录中的⽂件组)执⾏指定的 Command。
系统帮助的格式:FOR /D %%variable IN (set) DO command
他主要⽤于⽬录搜索,不会搜索⽂件,看这样的例⼦
@echo off
for /d %%i in (*) do @echo %%i
pause
把他保存放在C盘根⽬录执⾏,就会把C盘⽬录下的全部⽬录名字打印出来,⽽⽂件名字⼀个也不显⽰!
在来⼀个,⽐如我们要把当前路径下⽂件夹的名字只有1-3个字母的打出来
@echo off
for /d %%i in (???) do @echo %%i
pause
这样的话如果你当前⽬录下有⽬录名字只有1-3个字母的,就会显⽰出来,没有就不显⽰了
思考题⽬:
@echo off
for /d %%i in (window?) do @echo %%i
pause
保存到C盘下执⾏,会显⽰什么呢?⾃⼰看吧!
/D参数只能显⽰当前⽬录下的⽬录名字,这个⼤家要注意!
/R
递归
进⼊根⽬录树 [Drive:]Path,在树的每个⽬录中执⾏ for 语句。如果在 /R 后没有指定⽬录,则认为是
当前⽬录。如果 Set 只是⼀个句点 (.),则只枚举⽬录树。
护士节祝福系统帮助的格式:FOR /R [[drive:]path] %%variable IN (set) DO command
上⾯我们知道,/D只能显⽰当前路径下的⽬录名字,那么现在这个/R也是和⽬录有关,他能⼲嘛呢?放⼼他⽐
/D强⼤多了!
他可以把当前或者你指定路径下的⽂件名字全部读取,注意是⽂件名字,有什么⽤看例⼦!
@echo off
for /r c:/ %%i in (*.exe) do @echo %%i
pause
咋们把这个BAT保存到D盘随便哪⾥然后执⾏,我会就会看到,他把C盘根⽬录,和每个⽬录的⼦⽬录下⾯全部
的EXE⽂件都列出来了,这⾥的c:/就是⽬录了。
再来⼀个
@echo off
for /r %%i in (*.exe) do @echo %%i
pause
参数不⼀样了,这个命令前⾯没加那个C:/也就是搜索路径,这样他就会以当前⽬录为搜索路径,⽐如你这
个BAT你把他防灾d:/test⽬录下执⾏,那么他就会把D:/test⽬录和他下⾯的⼦⽬录的全部EXE⽂件列出
来!!!
/L
迭代数值范围
使⽤迭代变量设置起始值 (Start#),然后逐步执⾏⼀组范围的值,直到该值超过所设置的终⽌值 (End#)
。/L 将通过对 Start# 与 End# 进⾏⽐较来执⾏迭代变量。如果 Start# ⼩于 End#,就会执⾏该命令。
如果迭代变量超过 End#,则命令解释程序退出此循环。还可以使⽤负的 Step# 以递减数值的⽅式逐
步执
⾏此范围内的值。例如,(1,1,5) ⽣成序列 1 2 3 4 5,⽽ (5,-1,1) 则⽣成序列 (5 4 3 2 1)。语法是:
系统帮助的格式:for /L %% Variable in (Start#,Step#,End#) do Command
例如:
@echo off
for /l %%i in (1,1,5) do @echo %%i
pause
保存执⾏看效果,他会打印从1 2 3 4 5  这样5个数字
(1,1,5)这个参数也就是表⽰从1开始每次加1直到5终⽌!
再看这个例⼦
@echo off
for /l %%i in (1,1,5) do start cmd
pause
执⾏后是不是吓了⼀跳,怎么多了5个CMD窗⼝,呵呵!如果把那个 (1,1,5)改成 (1,1,65535)会有什么结果,
我先告诉⼤家,会打开65535个CMD窗⼝....这么多你不死机算你强!
当然我们也可以把那个start cmd改成md %%i 这样就会建⽴指定个⽬录了!!!名字为1-65535
看完这个被我赋予破坏性质的参数后,我们来看最后⼀个参数
/f
含有/F的for详细说明
含有/F的for有很⼤的⽤处,在批处理中使⽤的最多,⽤法如下:
格式:
FOR /F ["options"] %%i IN (file) DO command
FOR /F ["options"] %%i IN ("string") DO command
FOR /F ["options"] %%i IN ('command') DO command
这个可能是最常⽤的,也是最强的命令,主要⽤来处理⽂件和⼀些命令的输出结果。
file代表⼀个或多个⽂件
string 代表字符串
command代表命令
["options"] 可选
对于FOR /F %%i IN (file) DO command
file为⽂件名,按照官⽅的说法是,for会依次将file中的⽂件打开,并且在进⾏到下⼀个⽂件之前将每个⽂件读取到内存,按照每⼀⾏分成⼀个⼀个的元素,忽略空⽩的⾏,看个例⼦。
假如⽂件a.txt中有如下内容:
第1⾏第1列第1⾏第2列第1⾏第3列
第2⾏第1列第2⾏第2列第2⾏第3列
第3⾏第1列第3⾏第2列第3⾏第3列
你想显⽰a.txt中的内容,会⽤什么命令呢?当然是type,
for也可以完成同样的命令:
for /f %%i in (a.txt) do echo %%i
还是先从括号执⾏,因为含有参数/f,所以for会先打开a.txt,然后读出a.txt⾥⾯的所有内容,把它作为⼀个集合,并且以每⼀⾏作为⼀个元素,所以会产⽣这样的集合,
{“第1⾏第1列第1⾏第2列第1⾏第3列”, //第⼀个元素
“第2⾏第1列第2⾏第2列第2⾏第3列”, //第⼆个元素
“第3⾏第1列第3⾏第2列第3⾏第3列”} //第三个元素
集合中只有3个元素,同样⽤%%i依次代替每个元素,然后执⾏do后⾯的命令。
具体过程:
⽤%%i代替“第1⾏第1列第1⾏第2列第1⾏第3列”,执⾏do后⾯的echo %%i,显⽰“第1⾏第1列第1⾏第2列第1⾏第3列”,
⽤%%i代替“第2⾏第1列第2⾏第2列第2⾏第3列”,执⾏echo %%i,显⽰“第2⾏第1列第2⾏第2列第2⾏第3列”,
依次,直到每个元素都代替完为⽌。
为了加强理解/f的作⽤,请执⾏⼀下两个命令,对⽐即可明⽩:
for /f %%i in (a.txt) do echo %%i //这个会显⽰a.txt⾥⾯的内容,因为/f的作⽤,会读出a.txt中
的内容。
for %%i in (a.txt) do echo %%i //⽽这个只会显⽰a.txt这个名字,并不会读取其中的内容。
通过上⾯的学习,我们发现for /f会默认以每⼀⾏来作为⼀个元素,但是如果我们还想把每⼀⾏再分解更⼩的内容,该怎么办呢?不⽤担⼼,for命令还为我们提供了更详细的参数,使我们将每⼀⾏分为更⼩的元素成为可能。
它们就是:delims和tokens
delims ⽤来告诉for每⼀⾏应该拿什么作为分隔符,默认的分隔符是空格和tab键
⽐如,还是上⾯的⽂件,我们执⾏下⾯的命令:
for /f "delims= " %%i in (a.txt) do echo %%i
显⽰的结果是:
第1⾏第1列
第2⾏第1列
第3⾏第1列
为什么是这样的呢。因为这⾥有了delims这个参数,=后⾯有⼀个空格,意思是再将每个元素以空格分割,默认是只取分割之后的第⼀个元素。
执⾏过程是:
将第⼀个元素“第1⾏第1列第1⾏第2列第1⾏第3列”分成三个元素:“第1⾏第1列” “第1⾏第2列” “第1⾏第3列”,它默认只取第⼀个,即“第1⾏第1列”,然后执⾏do后⾯的命令,依次类推。
但是这样还是有局限的,如果我们想要每⼀⾏的第⼆列元素,那⼜如何呢?
这时候,tokens跳出来说,我能做到。
它的作⽤就是当你通过delims将每⼀⾏分为更⼩的元素时,由它来控制要取哪⼀个或哪⼏个。
还是上⾯的例⼦,执⾏如下命令:
for /f "tokens=2 delims= " %%i in (a.txt) do echo %%i
执⾏结果:
第1⾏第2列
第2⾏第2列
第3⾏第2列
如果要显⽰第三列,那就换成tokens=3。
同时tokens⽀持通配符*,以及限定范围。
如果要显⽰第⼆列和第三列,则换成tokens=2,3或tokens=2-3,如果还有更多的则为:tokens=2-10之类的。
此时的命令为:
for /f "tokens=2,3 delims= " %%i in (a.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=* delims= " %%i in (a.txt) do echo %%i
执⾏结果为:
第1⾏第1列第1⾏第2列第1⾏第3列
第2⾏第1列第2⾏第2列第2⾏第3列
第3⾏第1列第3⾏第2列第3⾏第3列
其实就跟for /f %%i in (a.txt) do echo %%i的执⾏结果是⼀样的。
再如:
for /f "tokens=2,* delims= " %%i in (a.txt) do echo %%i %%j
执⾏结果为:
第1⾏第2列第1⾏第3列
第2⾏第2列第2⾏第3列
第3⾏第2列第3⾏第3列
⽤%%i代替第⼆列,⽤%%j代替剩余的所有
最后还有skip合eol,这俩个简单,skip就是要忽略⽂件的前多少⾏,⽽eol⽤来指定当⼀⾏以什么符号开始时,就忽略它。
⽐如:
for /f "skip=2 tokens=*" %%i in (a.txt) do echo %%i
结果为:
第3⾏第1列第3⾏第2列第3⾏第3列
⽤skip来告诉for跳过前两⾏。
如果不加tokens=*的话,执⾏结果为:
第3⾏第1列
不知道怎么回事。
再如,当a.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 (a.txt) do echo %%i结果是:
第3⾏第1列第3⾏第2列第3⾏第3列
⽤eol来告诉for忽略以“.”开头的⾏。
同样也必须加tokens=*,否则只会显⽰“第3⾏第1列
======================================================
梦见自己买衣服
终极dos批处理循环命令详解
格式:FOR [参数] %%变量名 IN (相关⽂件或命令)  DO 执⾏的命令
  作⽤:对⼀个或⼀组⽂件,字符串或命令结果中的每⼀个对象执⾏特定命令,达到我们想要的结果。
  注意:在批处理⽂件中使⽤ FOR 命令时,指定变量请使⽤ %%variable,⽽不要⽤ %variable。变量名称是区分⼤⼩写的,所以 %i 不同于 %I.
  关于:for命令可以带参数或不带参数,带参数时⽀持以下参数:/d /l /r /f
  下⾯分别解释⼀下
  ===
  零:⽆参数时:
  ---
  FOR %variable IN (set) DO command [command-parameters]
  %variable 指定⼀个单⼀字母可替换的参数。
  (set)      指定⼀个或⼀组⽂件。可以使⽤通配符。
  command    指定对每个⽂件执⾏的命令。
  command-parameters
  为特定命令指定参数或命令⾏开关。
  TTT⽰例:
  for %%i in (t*.*) do echo %%i --显⽰当前⽬录下与t*.*相匹配的⽂件(只显⽰⽂件名,不显⽰路径)
  for %%i in (d:/mydocuments/*.doc) do @echo %%i --显⽰d:/mydocuments/⽬录下与*.doc相匹配的⽂件
  ===
  ⼀、参数 /d (参数只能显⽰当前⽬录下的⽬录名字)
  ---
  格式:FOR /D %variable IN (set) DO command [command-parameters]
  这个参数主要⽤于⽬录搜索,不会搜索⽂件,/D 参数只能显⽰当前⽬录下的⽬录名字。(TTT特别说明:只会搜索指定⽬录下的⽬录,不会搜索再下⼀级的⽬录。)
  TTT⽰例:
  for /d %%i in (c:/*) do echo %%i --显⽰c盘根⽬录下的所有⽬录
环境调查报告范文  for /d %%i in (???) do echo %%i --显⽰当前⽬录下名字只有1-3个字母的⽬录
  ===
  ⼆、参数 /R (搜索指定路径及所有⼦⽬录中与set相符合的所有⽂件)
  ---
  格式:FOR /R [[drive:]path] %variable IN (set) DO command [command-parameters]
  此命令会搜索指定路径及所有⼦⽬录中与set相符合的所有⽂件,注意是指定路径及所有⼦⽬录。
  1、set中的⽂件名如果含有通配符(?或*),则列举/R参数指定的⽬录及其下⾯的所⽤⼦⽬录中与set相符合的所有⽂件,⽆相符⽂件的⽬录则不列举。
  2、如果set中为具体⽂件名,不含通配符,则枚举该⽬录树(即列举该⽬录及其下⾯的所有⼦⽬录)(并在后⾯加上具体的⽂件名),⽽不管set中的指定⽂件是否存在。
  例:for /r c:/ %%i in (*.exe) do echo %%i --把C盘根⽬录,和每个⽬录的⼦⽬录下⾯全部的EXE⽂件都列出来了!!!!
  TTT⽰例:
  for /r c:/ %%i in (boot.ini) do echo %%i --枚举了c盘所有⽬录
  for /r d:/backup %%i in (1) do echo %%i --枚举d/backup⽬录
  for /r c:/ %%i in (boot.ini) do if exist %%i echo %%i --很好的搜索命令,列举boot.ini存在的⽬录
  ===
  三、参数 /L (该集表⽰以增量形式从开始到结束的⼀个数字序列。可以使⽤负的 Step)
  ---
  格式:FOR /L %variable IN (start,step,end) DO command [command-parameters]
  该集表⽰以增量形式从开始到结束的⼀个数字序列。可以使⽤负的 Step
  TTT⽰例:
  for /l %%i in (1,1,5) do @echo %%i --输出1 2 3 4 5
  for /l %%i in (1,2,10) do @echo %%i --输出1,3,5,7,9
  for /l %%i in (100,-20,1) do @echo %%i --输出100,80,60,40,20
  for /l %%i in (1,1,5) do start cmd --打开5个CMD窗⼝
  for /l %%i in (1,1,5) do md %%i --建⽴从1~5共5个⽂件夹
  for /l %%i in (1,1,5) do rd /q %%i --删除从1~5共5个⽂件夹
四、参数 /F (使⽤⽂件解析来处理命令输出、字符串及⽂件内容。)
  ---
  这个参数是最难的,参数⼜多,先简单的解释⼀下:for命令带这个参数可以分析⽂件内容,字符串内容或某⼀命令输出的结果,并通过设置option得我们想要的结果。
  以下是某⾼⼿的解释,感觉有点太专业了,⾃认为不太容易理解,也列⼀下:
  [迭代及⽂件解析--使⽤⽂件解析来处理命令输出、字符串及⽂件内容。使⽤迭代变量定义要检查的内容或字符串,并使⽤各种options选项进⼀步修改解析⽅式。使⽤options 令牌选项指定哪些令牌应该作为迭代变量传递。
  请注意:在没有使⽤令牌选项时,/F 将只检查第⼀个令牌。⽂件解析过程包括读取输出、字符串或⽂件内容,将其分成独⽴的⽂本⾏以及再将每⾏解析成零个或更多个令牌。然后通过设置为令牌的迭代变量值,调⽤ for 循环。
  默认情况下,/F 传递每个⽂件每⼀⾏的第⼀个空⽩分隔符号。跳过空⾏。]
  +++
  格式:
  FOR /F ["options"] %variable IN (file-set) DO command [command-parameters]
  FOR /F ["options"] %variable IN ("string") DO command [command-parameters]
  FOR /F ["options"] %variable IN ('command') DO command [command-parameters]
  或者,如果有 usebackq 选项:
  FOR /F ["options"] %variable IN (file-set) DO command [command-parameters]
  FOR /F ["options"] %variable IN ("string") DO command [command-parameters]
  FOR /F ["options"] %variable IN ('command') DO command [command-parameters]
  TTT说明:以上是WinXP系统中的帮助内容,你可以注意到,两者完全相同,这其实是系统的错误,第⼆段“如果有 usebackq 选项:”应该以下的内容:
  FOR /F ["options"] %variable IN ("file-set") DO command [command-parameters]
  FOR /F ["options"] %variable IN ('string') DO command [command-parameters]
  FOR /F ["options"] %variable IN (`command`) DO command [command-parameters] --(`command`中的引号为反引号,是键盘上数字1左⾯的那个键)
  +++
  (TTT说明:下⾯是详细的解释,⼤部分是系统中的帮助内容,也有些错误(怪不得for命令这么难学),
已经被我纠正了。)
1) OPTION关键字详解:
  eol=c:指⼀个⾏注释字符的结尾(就⼀个)。例如:eol=; --忽略以分号打头的那些⾏;
  skip=n:指在⽂件开始时忽略的⾏数。例如:skip=2 --忽略2⾏;
  delims=xxx:指分隔符集。这个替换了空格和跳格键的默认分隔符集。例如:[delims=, ] --指定⽤逗号,空格对字符串进⾏分隔。
  tokens=x,y,m-n:指每⾏的哪⼀个符号被传递到每个迭代的 for 本⾝。这会导致额外变量名称的分配。m-n格式为⼀个范围。通过 nth 符号指定 mth。如果符号字符串中的最后⼀个字符是星号,那么额外的变量将在最后⼀个符号解析之后分配并接受⾏的保留⽂本。例如:tokens=2,3* --将每⾏中的第⼆个和第三个符号传递给 for 程序体;tokens=2,3* ... i% --将会把取到的第⼆个字符串赋给i%,第三个赋给j%,剩下的赋给k%。
  关于usebackq,不同版本的系统提⽰不同的帮助,不过都有助于理解,所以都摘抄如下:
血湘西剧情介绍  (1),usebackq:使⽤后引号(键盘上数字1左⾯的那个键`)。未使⽤参数usebackq时:file-set表⽰
⽂件,不能加引号,所以不能含有空格;加双引号表⽰字符串,即"string";加单引号表⽰执⾏命令,即'command'。使⽤参数usebackq时:file-set和"file-set"都表⽰⽂件,当⽂件路径或名称中有空格时,就可以⽤双引号括起来;单引号表⽰字符串,即'string';后引号表⽰命令执⾏,即`command`。(此段是WinXP系统中的帮助)
  (2),usebackq:指定新语法已在下类情况中使⽤:在作为命令执⾏⼀个后引号的字符串;并且⼀个单引号字符为⽂字字符串命令;并允许在filenameset中使⽤双引号扩起⽂件名称。
  以上两条结合着看,其实已经可以明⽩了,我再说明⼀下:
  其实这个参数的⽬的就是为了处理带有空格的⽂件名。如果您要处理的⽂件名和路径中含有空格,如果直接使⽤,会提⽰不到⽂件。如果你⽤双引号将⽂件名和路径括起来。这时候将作为字符串处理,⽽不是作为⽂件了。为了应对这种情况,所以才增加了这个“usebackq”参数。如果使⽤了这个参数,对于括号中的加双引号的集合,系统就可以认为是⽂件了;真正的字符串要加单引号;命令要加反引号。
  2) file-set 为⼀个或多个⽂件名。继续到 file-set 中的下⼀个⽂件之前,每份⽂件都已被打开、读取并经过处理。处理包括读取⽂件,将其分成⼀⾏⾏的⽂字,然后将每⾏解析成零或更多的符号。然后⽤已到的符号字符串变量值调⽤ For 循环。以默认⽅式,/F 通过每个⽂件的每⼀⾏中分开的第⼀个空
⽩符号。跳过空⽩⾏。您可通过指定可选"options"参数替代默认解析操作。这个带引号的字符串包括⼀个或多个指定不同解析选项的关键字。
  3) %i:专门在 for 语句中得到说明,%j 和 %k 是通过tokens= 选项专门得到说明的。您可以通过 tokens= ⼀⾏指定最多 26 个符号,只要不试图说明⼀个⾼于字母 'z' 或'Z' 的变量。请记住,FOR 变量是单⼀字母、分⼤⼩写和全局的;⽽且,同时不能有 52 个以上都在使⽤中。
  (TTT补充说明:
  ⼀般在tokens后只指定第⼀个参数,如%%i或%%a,在后⾯使⽤第⼆个及两个以上的参数,⾃动按顺序往下排即可。如前⾯指定的是%%a,后⾯则⽤%%b代表第⼆个结果,%%c代表第三个结果。。。测试了⼀下tokens后指定多个变量名,没有测试成功,应该是不可以的。所以token后只能跟要使⽤的第⼀个变量名
  如果使⽤的变量名超过了%z或%Z,就⽆法使⽤了,曾经以为会循环过来:如%%z后可以使⽤%%a或%%A,但经测试,这是不可以的。
  如:for /f "tokens=1,2,3* delims=-, " %%y in ("aa bb,cc-dd ee") do echo %%y %%z %%A %%a --只会输出前两个字符串,后⾯的两个变量是⽆效的。)
  +++
  以下是系统提供的范例:
  FOR /F "eol=; tokens=2,3* delims=, " %i in () do @echo %i %j %k --
  说明:会分析 中的每⼀⾏,
  eol=; --忽略以分号打头的那些⾏;
  tokens=2,3* --将每⾏中的第⼆个和第三个符号传递给 for 程序体;
  delims= , --⽤逗号和/或空格定界符号。
  %i --这个 for 程序体的语句引⽤ %i 来取得取得的⾸个字符串(本例中为第⼆个符号),引⽤ %j 来取得第⼆个字符串(本例中为第三个符号)引⽤ %k来取得第三个符号后的所有剩余符号。
  (TTT说明:上述例⼦和说明中明显的错误,%i应该换为%%i(帮助中有明确的说明:指定变量请使⽤ %%variable,⽽不要⽤ %variable,误导)
  +++
  TTT:下⾯列我做的⼏个例⼦:
  1,分析⽂件的例⼦
  FOR /F "eol=; tokens=1,2* delims=,- " %%i in (d:/) do echo %%i %%j %%k
  2,分析字符串的例⼦:
  for /f "tokens=1,2,3* delims=-, " %%i in ("aa bb,cc-dd ee") do echo %%i %%j %%k %%l
  3,分析命令输出的例⼦:
  FOR /F "tokens=1* delims==" %%i IN ('set') DO @echo [%%i----%%j]
  如果使⽤了usebackq参数后,命令如下,结果与上⾯的完全相同。
  1,分析⽂件的例⼦
  FOR /F "usebackq eol=; tokens=1,2* delims=,- " %%i in ("d:/") do echo %%i %%j %%k
  2,分析字符串的例⼦:
  for /f "usebackq tokens=1,2,3* delims=-, " %%i in ('aa bb,cc-dd ee') do echo %%i %%j %%k %%l
  3,分析命令输出的例⼦:(会枚举当前环境中的环境变量名称和值。)
  FOR /F "usebackq tokens=1* delims==" %%i IN (`set`) DO @echo [%%i----%%j]
  结果⼤家可以试⼀下,很容易就明⽩的。
  ===
  FOR命令中的变量
  ---
  FOR 变量参照的替换已被增强。您现在可以使⽤下列选项语法:
  ~I        - 删除任何引号("),扩充 %I
  %~fI        - 将 %I 扩充到⼀个完全合格的路径名
  %~dI        - 仅将 %I 扩充到⼀个驱动器号
  %~pI        - 仅将 %I 扩充到⼀个路径
  %~nI        - 仅将 %I 扩充到⼀个⽂件名
  %~xI        - 仅将 %I 扩充到⼀个⽂件扩展名
  %~sI        - 扩充的路径只含有短名
  %~aI        - 将 %I 扩充到⽂件的⽂件属性
  %~tI        - 将 %I 扩充到⽂件的⽇期/时间
  %~zI        - 将 %I 扩充到⽂件的⼤⼩
  %~$PATH:I  - 查列在路径环境变量的⽬录(TTT提⽰:是环境变量path的⽬录),并将 %I 扩充到到的第⼀个完全合格的名称。如果环境变量名未被定义,或者没有到⽂件,此组合键会扩充到空字符串
  此外,还可以组合修饰符来得到多重结果:
  %~dpI      - 仅将 %I 扩充到⼀个驱动器号和路径
  %~nxI      - 仅将 %I 扩充到⼀个⽂件名和扩展名
  %~fsI      - 仅将 %I 扩充到⼀个带有短名的完整路径名
  %~dp$PATH:i - 查列在路径环境变量的⽬录,并将 %I 扩充到到的第⼀个驱动器号和路径。
  %~ftzaI    - 将 %I 扩充到类似输出线路的 DIR
  在以上例⼦中,%I 和 PATH 可⽤其他有效数值代替。%~ 语法⽤⼀个有效的 FOR 变量名终⽌。选取类似 %I 的⼤写变量名⽐较易读,⽽且避免与不分⼤⼩写的组合键混淆。
  (以上是系统帮助的内容)
  我们可以看到每⾏都有⼀个⼤写字母"I",这个I其实就是我们在FOR带⼊的变量,例如:
  FOR /F "usebackq eol=; tokens=1,2* delims=,- " %%x in ("d:/") do echo %%x %%y %%z
  这⾥我们就要把那个x,y,z改成%~fx,%~fy,%~fz。
  +++
  TTT特例:以下是我根据以上说明作的⼀个综合的例⼦,可以直接复制到记事本⾥,保存为bat格式(c盘下任⼀⽬录),运⾏后,可以直观的看到扩展后的效果。
  @echo off
  echo ---显⽰"dir c:/boot.ini /b /ah"
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 不扩展变量 %%i
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~fI %%~fi --扩充到⼀个完全合格的路径名
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~dI %%~di --仅将变量扩充到⼀个驱动器号
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~pI %%~pi --仅将变量扩充到⼀个路径
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~nI %%~ni --仅将变量扩充到⼀个⽂件名
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~xI %%~xi --仅将变量扩充到⼀个⽂件扩展名
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~sI %%~si --扩充的路径只含有短名
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~aI %%~ai --将变量扩充到⽂件的⽂件属性
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~tI %%~ti --将变量扩充到⽂件的⽇期/时间
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~zI %%~zi --将变量扩充到⽂件的⼤⼩
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~$PATH:I %%~$PATH:i --查列在路径环境变量的⽬录,并将变量扩充到到的第⼀个完全合格的名称  echo ---以下显⽰组合修饰符来得到多重结果---:
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~dpI %%~dpi --仅将变量扩充到
⼀个驱动器号和路径
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~nxI %%~nxi --仅将变量扩充到⼀个⽂件名和扩展名
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~fsI %%~fsI --仅将变量扩充到⼀个带有短名的完整路径名
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~dp$PATH:I %%~dp$PATH:i --查列在路径环境变量的⽬录,并将变量扩充到到的第⼀个驱动器号和路径
  for /f "delims==" %%i in ('dir c:/boot.ini /b /ah') do echo 扩展变量到~ftzaI %%~ftzai --将变量扩充到类似输出线路的DIR
  echo.
  echo ---显⽰"dir C:/WINDOWS/ /b"
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 不扩展变量 %%i
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~fI %%~fi --扩充到⼀个完全合格的路径名
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~dI %%~di --仅将变量扩充到⼀个驱动器号
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~pI %%~pi --仅将变量扩充到⼀个路径
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~nI %%~ni --仅将变量扩充到⼀个⽂件名
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~xI %%~xi --仅将变量扩充到⼀个⽂件扩展名
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~sI %%~si --扩充的路径只含有短名
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~aI %%~ai --将变量扩充到⽂件的⽂件属性
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~tI %%~ti --将变量扩充到⽂件的⽇期/时间
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~zI %%~zi --将变量扩充到⽂件的⼤⼩
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~$PATH:I %%~$PATH:i --查列在路径环境变量的⽬录,并将变量扩充到到的第⼀个完全合格的名称
  echo ---以下显⽰组合修饰符来得到多重结果---:
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~dpI %%~dpi --仅将变量扩充到⼀个驱动器号和路径
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~nxI %%~nxi --仅将变量扩充到⼀个⽂件名和扩展名
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~fsI %%~fsI --仅将变量扩充到⼀个带有短名的完整路径名
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~dp$PATH:I %%~dp$PATH:i --查列在路径环境变量的⽬录,并将变量扩充到到的第⼀个驱动器号和路径
  for /f "delims==" %%i in ('dir C:/WINDOWS/ /b') do echo 扩展变量到~ftzaI %%~ftzai --将变量扩充到类似输出线路的DIR
  Pause
甄子丹老婆汪诗诗
  TTT说明:
  1,以上命令中,%%~fsI⽆法显⽰,估计是系统错误,因为%%~fI是扩充到⼀个完全合格的路径名,%%~sI只含有短⽂件名,本⾝是相互⽭盾的,所以出错。不知是系统的错误还是在考我们~~
  2,以上命令如果保存在别的盘中,⽆法显⽰正确的驱动器和路径。
  3,如果想要%%~dp$PATH:i正常显⽰,要保证环境变量path中确实有这个路径:C:/WINDOWS/system32。
 下⾯依次说明⼀下:
  +++
  ⼀、 ~I      - 删除任何引号("),扩展 %I
  ---
  这个变量的作⽤就如他的说明,删除引号!
  删除引号规则如下(BAT兄补充!):
  1、若字符串⾸尾同时存在引号,则删除⾸尾的引号;
  2、若字符串尾不存在引号,则删除字符串⾸的引号;
  3、如果字符串中间存在引号,或者只在尾部存在引号,则不删除。
  龙卷风补充:⽆头不删,有头连尾删。临渊羡鱼的下一句
  我们来看这个例⼦,⾸先建⽴临时⽂件,内容如下
  "1111
  "2222"
  3333"
  "4444"44
  "55"55"55
  也可建⽴个BAT⽂件代码如下:
  @echo off
  echo ^"1111&
  echo "2222">&
  echo 3333^">&
  echo "4444"44>&
  echo ^"55"55"55>&
  rem 上⾯建⽴临时⽂件,注意不成对的引号要加转义字符^,重定向符号前不要留空格
  FOR /F "delims=" %%i IN () DO echo  %%~i
  pause
 
  执⾏后,我们看CMD的回显如下:
  1111          #字符串前的引号被删除了
  2222          #字符串⾸尾的引号都被删除了
  3333"      #字符串前⽆引号,后⾯的引号保留
  4444"44        #字符串前⾯的引号删除了,⽽中间的引号保留
  55"55"55    #字符串前⾯的引号删除了,⽽中间的引号保留
  请按任意键继续. . .
  结果和之前中的内容对⽐⼀下,我们会发现第1、2、5⾏的引号都消失了,这就是删除引号~i的作⽤了!
  +++
  ⼆、 %~fI        - 将 %I 扩展到⼀个完全合格的路径名
  ⽰例:
  把代码保存放在随便哪个地⽅,我这⾥就放桌⾯吧.
  FOR /F "delims==" %%i IN ('dir /b') DO @echo  %%~fi
  pause
  执⾏后显⽰内容如下

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。