在SharePoint遷移中,要同步新舊用戶SID,但是用戶太多,所以決定用批處理一行行讀取導出的User.txt(每一行是一條用戶信息),再針對每一條用戶記錄進行操作。 於是學習參考了上面大俠的一些知識。主要用到的是/f命令,
(想了下,還是整個貼到自己空間來了)
我需要的是要讀取每一條的第一列信息,如下格式
ary,Ary Hong,,[email protected],,,,
我是需要用戶名ary,於是如下:
@echo off
for /f "delims=," %%i in (users.txt) do ......
每一行中,各信息以“,”分隔,所以定義了 "delims=,"後,就會自動讀取以“,”分隔的第一個元素了。
雖然可以讀取每一行中所需要的信息,但每次執行批處理的時候都找不到記錄,後來才發現時文本文件的編碼在作怪,如果文件編碼是ANSI,是可以讀取的,如果是UniCode就無法識別了。不曉得批處理文件的所有文本處理的命令都是有這個限制的,以後得留心了。
轉載自: http://hi.baidu.com/zch11230/blog/item/125ddc8bba61fe15c8fc7aa2.html
FOR這條命令基本上都被用來處理文本,但還有其他一些好用的功能! 看看他的基本格式(這裏我引用的是批處理中的格式,直接在命令行只需要一個%號) 參數:FOR有4個參數 /d /l /r /f 他們的作用我在下面用例子解釋 可以在CMD輸入for /?看系統提供的幫助!對照一下 %%variable 指定一個單一字母可替換的參數。
/d 錄(而不是指定目錄中的文件組)執行指定的 Command。 系統幫助的格式:FOR /D %%variable IN (set) DO command @echo off 把他保存放在C盤根目錄執行,就會把C盤目錄下的全部目錄名字打印出來,而文件名字一個也不顯示! @echo off 這樣的話如果你當前目錄下有目錄名字只有1-3個字母的,就會顯示出來,沒有就不顯示了
@echo off 保存到C盤下執行,會顯示什麼呢?自己看吧!
/R 當前目錄。如果 Set 只是一個句點 (.),則只枚舉目錄樹。 上面我們知道,/D只能顯示當前路徑下的目錄名字,那麼現在這個/R也是和目錄有關,他能幹嘛呢?放心他比 /D強大多了! @echo off 咋們把這個BAT保存到D盤隨便哪裏然後執行,我會就會看到,他把C盤根目錄,和每個目錄的子目錄下面全部 的EXE文件都列出來了,這裏的c:/就是目錄了。 再來一個 參數不一樣了,這個命令前面沒加那個C:/也就是搜索路徑,這樣他就會以當前目錄爲搜索路徑,比如你這 個BAT你把他防災d:/test目錄下執行,那麼他就會把D:/test目錄和他下面的子目錄的全部EXE文件列出 來!!!
。/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 保存執行看效果,他會打印從1 2 3 4 5 這樣5個數字 再看這個例子 執行後是不是嚇了一跳,怎麼多了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 ("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列
你想顯示a.txt中的內容,會用什麼命令呢?當然是type,type a.txt 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列
爲什麼是這樣的呢。因爲這裏有了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列 如果要顯示第三列,那就換成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列 對以通配符*,就是把這一行全部或者這一行的剩餘部分當作一個元素了。 比如:
for /f "tokens=* delims= " %%i in (a.txt) do echo %%i
執行結果爲:
第1行第1列 第1行第2列 第1行第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列
用%%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列 執行for /f "eol=. tokens=*" %%i in (a.txt) do echo %%i結果是:
第3行第1列 第3行第2列 第3行第3列 用eol來告訴for忽略以“.”開頭的行。 同樣也必須加tokens=*,否則只會顯示“第3行第1列”
在For命令語句的參數F中,最難理解的就是Delims和Tokens兩個選項,本文簡單的做一個比較和總結。
二、tokens |