DOS命令中的For

前幾天作安裝包,須要獲取某個目錄下全部文件夾的名字和路徑。原本想用C++寫段代碼,後來想起DOS有可能知足需求,因而研究了一下FOR命令,居然很是容易的達到目的,看來小看了DOS這個門口的東西。函數

 

說下個人需求吧,獲取指定目錄的子目錄下全部DLL文件,DLL名字和所在目錄相同。spa

先貼上個人代碼命令行

1 ::dir 目錄全路徑
2 for /r "dir" %%a in (.) do (
3     if exist "%%~dpa%%~na\%%~na.dll" (
4         echo "%%~dpa%%~na\%%~na.dll" 
5     )
6 )

幾句話就實現了,簡單吧~!!!code

 

FOR使用說明

FOR命令還有不少強大的功能,我本身還說不明白,看看官方幫助吧blog

對一組文件中的每個文件執行某個特定命令。

FOR %variable IN (set) DO command [command-parameters]

  %variable  指定一個單一字母可替換的參數。
  (set)      指定一個或一組文件。可使用通配符。
  command    指定對每一個文件執行的命令。
  command-parameters
             爲特定命令指定參數或命令行開關。

在批處理程序中使用 FOR 命令時,指定變量請使用 %%variable 
而不要用 %variable。變量名稱是區分大小寫的,因此 %i 不一樣於 %I.

若是啓用命令擴展,則會支持下列 FOR 命令的其餘格式:

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

    若是集中包含通配符,則指定與目錄名匹配,而不與文件名匹配。

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

    檢查以 [drive:]path 爲根的目錄樹,指向每一個目錄中的 FOR 語句。
    若是在 /R 後沒有指定目錄規範,則使用當前目錄。若是集僅爲一個單點(.)字符,
    則枚舉該目錄樹。

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

    該集表示以增量形式從開始到結束的一個數字序列。所以,(1,1,5)將產生序列
    1 2 3 4 5,(5,-1,1)將產生序列(5 4 3 2 1)

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]

    fileset 爲一個或多個文件名。繼續到 fileset 中的下一個文件以前,每份文件都被打開、讀取並通過處理。處理包括讀取文件,將其分紅一行行的文字,而後將每行解析成零或更多的符號。而後用已找到的符號字符串變量值調用 For 循環。
    以默認方式,/F 經過每一個文件的每一行中分開的第一個空白符號。跳過空白行。
    您可經過指定可選 "options" 參數替代默認解析操做。這個帶引號的字符串包括一個或多個指定不一樣解析選項的關鍵字。這些關鍵字爲:

        eol=c           - 指一個行註釋字符的結尾(就一個)
        skip=n          - 指在文件開始時忽略的行數。
        delims=xxx      - 指分隔符集。這個替換了空格和跳格鍵的
                          默認分隔符集。
        tokens=x,y,m-n  - 指每行的哪個符號被傳遞到每一個迭代
                          的 for 自己。這會致使額外變量名稱的分配。m-n
                          格式爲一個範圍。經過 nth 符號指定 mth。若是
                          符號字符串中的最後一個字符星號,
                          那麼額外的變量將在最後一個符號解析以後
                          分配並接受行的保留文本。
        usebackq        - 指定新語法已在下類狀況中使用:
                          在做爲命令執行一個後引號的字符串而且一個單
                          引號字符爲文字字符串命令並容許在 file-set
                          中使用雙引號擴起文件名稱。

    某些範例可能有助:

FOR /F "eol=; tokens=2,3* delims=, " %i in (myfile.txt) do @echo %i %j %k

    會分析 myfile.txt 中的每一行,忽略以分號打頭的那些行,將每行中的第二個和第三個符號傳遞給 for 函數體,用逗號和/或空格分隔符號。請注意,此 for 函數體的語句引用 %i 來    得到第二個符號,引用 %j 來得到第三個符號,引用 %k來得到第三個符號後的全部剩餘符號。
對於帶有空格的文件名,您須要用雙引號將文件名括起來。爲了用這種方式來使用雙引號,還須要使用 usebackq 選項,不然,雙引號會被理解成是用做定義某個要分析的字符串的。 %i 在 for 語句中顯式聲明,%j 和 %k 是經過tokens= 選項隱式聲明的。能夠經過 tokens= 一行指定最多 26 個符號,只要不試圖聲明一個高於字母 "z" 或"Z" 的變量。請記住,FOR 變量是單一字母、分大小寫和全局的變量;並且,不能同時使用超過 52 個。 還能夠在相鄰字符串上使用 FOR /F 分析邏輯,方法是,用單引號將括號之間的 file-set 括起來。這樣,該字符串會被看成一個文件中的一個單一輸入行進行解析。 最後,能夠用 FOR /F 命令來分析命令的輸出。方法是,將括號之間的 file-set 變成一個反括字符串。該字符串會被看成命令行,傳遞到一個子 CMD.EXE,其輸出會被捕獲到內存中,並被看成文件分析。如如下例子所示: FOR /F "usebackq delims==" %i IN (`set`) DO @echo %i 會枚舉當前環境中的環境變量名稱。 另外,FOR 變量參照的替換已被加強。您如今可使用下列 選項語法: %~I - 刪除任何引號("),擴展 %I %~fI - 將 %I 擴展到一個徹底合格的路徑名 %~dI - 僅將 %I 擴展到一個驅動器號 %~pI - 僅將 %I 擴展到一個路徑 %~nI - 僅將 %I 擴展到一個文件名 %~xI - 僅將 %I 擴展到一個文件擴展名 %~sI - 擴展的路徑只含有短名 %~aI - 將 %I 擴展到文件的文件屬性 %~tI - 將 %I 擴展到文件的日期/時間 %~zI - 將 %I 擴展到文件的大小 %~$PATH:I - 查找列在路徑環境變量的目錄,並將 %I 擴展 到找到的第一個徹底合格的名稱。若是環境變量名 未被定義,或者沒有找到文件,此組合鍵會擴展到 空字符串 能夠組合修飾符來獲得多重結果: %~dpI - 僅將 %I 擴展到一個驅動器號和路徑 %~nxI - 僅將 %I 擴展到一個文件名和擴展名 %~fsI - 僅將 %I 擴展到一個帶有短名的完整路徑名 %~dp$PATH:I - 搜索列在路徑環境變量的目錄,並將 %I 擴展 到找到的第一個驅動器號和路徑。 %~ftzaI - 將 %I 擴展到相似輸出線路的 DIR 在以上例子中,%I 和 PATH 可用其餘有效數值代替。%~ 語法 用一個有效的 FOR 變量名終止。選取相似 %I 的大寫變量名 比較易讀,並且避免與不分大小寫的組合鍵混淆。

 

最後說一下想法:相信本身,必定有更簡單的方式實現你的需求token

相關文章
相關標籤/搜索