批处理for命令详解(转) 批处理for命令详解
批處理for命令詳解(轉(zhuǎn))
批處理for命令詳解
2008-03-07 11:00
| FOR這條命令基本上都被用來(lái)處理文本,但還有其他一些好用的功能! 看看他的基本格式(這里我引用的是批處理中的格式,直接在命令行只需要一個(gè)%號(hào)) 參數(shù):FOR有4個(gè)參數(shù) /d?? /l?? /r?? /f?? 他們的作用我在下面用例子解釋 可以在CMD輸入for /?看系統(tǒng)提供的幫助!對(duì)照一下 %%variable 指定一個(gè)單一字母可替換的參數(shù)。
/d 錄(而不是指定目錄中的文件組)執(zhí)行指定的 Command。 系統(tǒng)幫助的格式:FOR /D %%variable IN (set) DO command @echo off 把他保存放在C盤根目錄執(zhí)行,就會(huì)把C盤目錄下的全部目錄名字打印出來(lái),而文件名字一個(gè)也不顯示! @echo off 這樣的話如果你當(dāng)前目錄下有目錄名字只有1-3個(gè)字母的,就會(huì)顯示出來(lái),沒有就不顯示了
@echo off 保存到C盤下執(zhí)行,會(huì)顯示什么呢?自己看吧! /R 當(dāng)前目錄。如果 Set 只是一個(gè)句點(diǎn) (.),則只枚舉目錄樹。 上面我們知道,/D只能顯示當(dāng)前路徑下的目錄名字,那么現(xiàn)在這個(gè)/R也是和目錄有關(guān),他能干嘛呢?放心他比 /D強(qiáng)大多了! @echo off 咋們把這個(gè)BAT保存到D盤隨便哪里然后執(zhí)行,我會(huì)就會(huì)看到,他把C盤根目錄,和每個(gè)目錄的子目錄下面全部 的EXE文件都列出來(lái)了,這里的c:/就是目錄了。 再來(lái)一個(gè) 參數(shù)不一樣了,這個(gè)命令前面沒加那個(gè)C:/也就是搜索路徑,這樣他就會(huì)以當(dāng)前目錄為搜索路徑,比如你這 個(gè)BAT你把他防災(zāi)d:/test目錄下執(zhí)行,那么他就會(huì)把D:/test目錄和他下面的子目錄的全部EXE文件列出 來(lái)!!!
。/L 將通過(guò)對(duì) Start# 與 End# 進(jìn)行比較來(lái)執(zhí)行迭代變量。如果 Start# 小于 End#,就會(huì)執(zhí)行該命令。 如果迭代變量超過(guò) End#,則命令解釋程序退出此循環(huán)。還可以使用負(fù)的 Step# 以遞減數(shù)值的方式逐步執(zhí) 行此范圍內(nèi)的值。例如,(1,1,5) 生成序列 1 2 3 4 5,而 (5,-1,1) 則生成序列 (5 4 3 2 1)。語(yǔ)法是: 系統(tǒng)幫助的格式:for /L %% Variable in (Start#,Step#,End#) do Command 例如: @echo off 保存執(zhí)行看效果,他會(huì)打印從1 2 3 4 5 這樣5個(gè)數(shù)字 再看這個(gè)例子 執(zhí)行后是不是嚇了一跳,怎么多了5個(gè)CMD窗口,呵呵!如果把那個(gè) (1,1,5)改成 (1,1,65535)會(huì)有什么結(jié)果, 我先告訴大家,會(huì)打開65535個(gè)CMD窗口....這么多你不死機(jī)算你強(qiáng)! 當(dāng)然我們也可以把那個(gè)start cmd改成md %%i 這樣就會(huì)建立指定個(gè)目錄了!!!名字為1-65535 看完這個(gè)被我賦予破壞性質(zhì)的參數(shù)后,我們來(lái)看最后一個(gè)參數(shù) /f 含有/F的for詳細(xì)說(shuō)明 含有/F的for有很大的用處,在批處理中使用的最多,用法如下: FOR /F ["options"] %%i IN ("string") DO command FOR /F ["options"] %%i IN ('command') DO command 這個(gè)可能是最常用的,也是最強(qiáng)的命令,主要用來(lái)處理文件和一些命令的輸出結(jié)果。 file代表一個(gè)或多個(gè)文件 string 代表字符串 command代表命令 ["options"] 可選 對(duì)于FOR /F %%i IN (file) DO command file為文件名,按照官方的說(shuō)法是,for會(huì)依次將file中的文件打開,并且在進(jìn)行到下一個(gè)文件之前將每個(gè)文件讀取到內(nèi)存,按照每一行分成一個(gè)一個(gè)的元素,忽略空白的行,看個(gè)例子。 假如文件a.txt中有如下內(nèi)容: 第1行第1列 第1行第2列 第1行第3列 你想顯示a.txt中的內(nèi)容,會(huì)用什么命令呢?當(dāng)然是type,type a.txt for也可以完成同樣的命令: for /f %%i in (a.txt) do echo %%i 還是先從括號(hào)執(zhí)行,因?yàn)楹袇?shù)/f,所以for會(huì)先打開a.txt,然后讀出a.txt里面的所有內(nèi)容,把它作為一個(gè)集合,并且以每一行作為一個(gè)元素,所以會(huì)產(chǎn)生這樣的集合, {"第1行第1列 第1行第2列 第1行第3列", //第一個(gè)元素 "第2行第1列 第2行第2列 第2行第3列", //第二個(gè)元素 "第3行第1列 第3行第2列 第3行第3列"}?? //第三個(gè)元素 集合中只有3個(gè)元素,同樣用%%i依次代替每個(gè)元素,然后執(zhí)行do后面的命令。 具體過(guò)程: 用%%i代替"第1行第1列 第1行第2列 第1行第3列",執(zhí)行do后面的echo %%i,顯示"第1行第1列 第1行第2列 第1行第3列", 用%%i代替"第2行第1列 第2行第2列 第2行第3列",執(zhí)行echo %%i,顯示"第2行第1列 第2行第2列 第2行第3列", 依次,直到每個(gè)元素都代替完為止。 為了加強(qiáng)理解/f的作用,請(qǐng)執(zhí)行一下兩個(gè)命令,對(duì)比即可明白: for /f %%i in (a.txt) do echo %%i //這個(gè)會(huì)顯示a.txt里面的內(nèi)容,因?yàn)?f的作用,會(huì)讀出a.txt中 for %%i in (a.txt) do echo %%i //而這個(gè)只會(huì)顯示a.txt這個(gè)名字,并不會(huì)讀取其中的內(nèi)容。 通過(guò)上面的學(xué)習(xí),我們發(fā)現(xiàn)for /f會(huì)默認(rèn)以每一行來(lái)作為一個(gè)元素,但是如果我們還想把每一行再分解更小的內(nèi)容,該怎么辦呢?不用擔(dān)心,for命令還為我們提供了更詳細(xì)的參數(shù),使我們將每一行分為更小的元素成為可能。 它們就是:delims和tokens delims 用來(lái)告訴for每一行應(yīng)該拿什么作為分隔符,默認(rèn)的分隔符是空格和tab鍵 比如,還是上面的文件,我們執(zhí)行下面的命令: for /f "delims= " %%i in (a.txt) do echo %%i 顯示的結(jié)果是: 第1行第1列 為什么是這樣的呢。因?yàn)檫@里有了delims這個(gè)參數(shù),=后面有一個(gè)空格,意思是再將每個(gè)元素以空格分割,默認(rèn)是只取分割之后的第一個(gè)元素。 執(zhí)行過(guò)程是: 將第一個(gè)元素"第1行第1列 第1行第2列 第1行第3列"分成三個(gè)元素:"第1行第1列" "第1行第2列" "第1行第3列",它默認(rèn)只取第一個(gè),即"第1行第1列",然后執(zhí)行do后面的命令,依次類推。 但是這樣還是有局限的,如果我們想要每一行的第二列元素,那又如何呢? 這時(shí)候,tokens跳出來(lái)說(shuō),我能做到。 它的作用就是當(dāng)你通過(guò)delims將每一行分為更小的元素時(shí),由它來(lái)控制要取哪一個(gè)或哪幾個(gè)。 還是上面的例子,執(zhí)行如下命令: for /f "tokens=2 delims= " %%i in (a.txt) do echo %%i 執(zhí)行結(jié)果: 第1行第2列 如果要顯示第三列,那就換成tokens=3。 同時(shí)tokens支持通配符*,以及限定范圍。 如果要顯示第二列和第三列,則換成tokens=2,3或tokens=2-3,如果還有更多的則為:tokens=2-10之類的。 此時(shí)的命令為: for /f "tokens=2,3 delims= " %%i in (a.txt) do echo %%i %%j 怎么多出一個(gè)%%j? 這是因?yàn)槟愕膖okens后面要取每一行的兩列,用%%i來(lái)替換第二列,用%%j來(lái)替換第三列。 并且必須是按照英文字母順序排列的,%%j不能換成%%k,因?yàn)閕后面是j 執(zhí)行結(jié)果為: 第1行第2列 第1行第3列 對(duì)以通配符*,就是把這一行全部或者這一行的剩余部分當(dāng)作一個(gè)元素了。 比如: for /f "tokens=* delims= " %%i in (a.txt) do echo %%i 執(zhí)行結(jié)果為: 第1行第1列 第1行第2列 第1行第3列 其實(shí)就跟for /f %%i in (a.txt) do echo %%i的執(zhí)行結(jié)果是一樣的。 再如: for /f "tokens=2,* delims= " %%i in (a.txt) do echo %%i %%j 執(zhí)行結(jié)果為: 第1行第2列 第1行第3列 用%%i代替第二列,用%%j代替剩余的所有 最后還有skip合eol,這倆個(gè)簡(jiǎn)單,skip就是要忽略文件的前多少行,而eol用來(lái)指定當(dāng)一行以什么符號(hào)開始時(shí),就忽略它。 比如: for /f "skip=2 tokens=*" %%i in (a.txt) do echo %%i 結(jié)果為: 第3行第1列 第3行第2列 第3行第3列 用skip來(lái)告訴for跳過(guò)前兩行。 如果不加tokens=*的話,執(zhí)行結(jié)果為: 第3行第1列 不知道怎么回事。 再如,當(dāng)a.txt內(nèi)容變成: .第1行第1列 第1行第2列 第1行第3列 執(zhí)行for /f "eol=. tokens=*" %%i in (a.txt) do echo %%i結(jié)果是: 第3行第1列 第3行第2列 第3行第3列 用eol來(lái)告訴for忽略以"."開頭的行。 同樣也必須加tokens=*,否則只會(huì)顯示"第3行第1列" |
總結(jié)
以上是生活随笔為你收集整理的批处理for命令详解(转) 批处理for命令详解的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 李德玉(1965-),男,博士,山西大学
- 下一篇: 作者:曾伟,电子科技大学副教授。