批處理命令學習筆記——Set命令
阿新 • • 發佈:2019-01-03
Set 命令
顯示、設定或刪除 cmd.exe 環境變數。
語法: SET [variable=[string]]
SET [[/a [expression]] [/p [variable=]] string] variable 指定環境變數名。string 指定要指派給變數的一系列字串。
要顯示當前環境變數,鍵入不帶引數的 SET。
如果命令副檔名被啟用,SET 會如下改變:
僅用一個變數名而不帶等號或者值啟用 SET 命令時,顯示所有字首與提供給SET命令相匹配的變數名及其值。例如:
SET P
會顯示所有以字母 P 打頭的變數。
如果在當前環境中找不到該變數名稱,SET 命令將把 ERRORLEVEL設定成 1。
SET 命令不允許變數名含有等號。
在 SET 命令中添加了兩個新命令列開關:
SET /A expression
SET /P variable=[promptString]
/A 命令列開關 指定等號右邊的字串為被評估的數字表達式。該表示式評估器很簡單並以遞減的優先權順序支援下列操作:
如果您使用任何邏輯或取餘操作符, 您需要將表示式字串用引號擴起來。在表示式中的任何非數字字串將作為環境變數名稱,這些環境變數名稱的值已在使用前轉換成數字。如果指定了一個環境變數名稱,但未在當前環境中定義,那麼值將被定為零。這使您可以使用環境變數值做計算而不用鍵入那些 % 符號來得到它們的值。如果 SET /A 在命令指令碼外的命令列執行的,那麼它顯示該表示式的最後值。該分配的操作符在分配的操作符左邊需要一個環境變數名稱。除十六進位制有 0x 字首, 八進位制有 0 字首的,數字值為十進位數字。因此, 0x12
與 18 和 022相同。請注意八進位制公式可能很容易搞混: 08 和 09 是無效的數字,因為 8 和 9 不是有效的八進位制位數。
/P 命令列開關 允許將變數數值設成使用者輸入的一行輸入。讀取輸入行之前,顯示指定的 promptString。promptString 可以是空的。
環境變數替換已如下增強:
下面這個例子比較全面地展示了 SET 命令的上述擴充套件功能:
延遲環境變數擴充套件
最後,添加了延遲環境變數擴充套件的支援。該支援總是按預設值被停用,但也可以通過 CMD.EXE 的 /V 命令列開關而被啟用/停用。請參閱 CMD /?。
考慮到讀取一行文字時所遇到的目前擴充的限制時,延遲環境變數擴充是很有用的,而不是執行的時候。以下例子說明直接變數擴充的問題:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "%VAR%" == "after" @echo If you see this, it worked
)
將不會顯示期望的訊息,因為在讀到第一個 IF 語句時,BOTH IF 語句中的 %VAR% 會被代替;原因是: 它包含 IF 的文體,IF 是一個複合語句。所以,複合語句中的 IF 實際上是在比較 "before" 和"after",這兩者永遠不會相等。同樣,以下這個例子也不會達到預期效果:
set LIST=
for %i in (*) do set LIST=%LIST% %i
echo %LIST%
原因是,它不會在目前的目錄中建立一個檔案列表,而只是將LIST 變數設成找到的最後一個檔案。這也是因為 %LIST% 在FOR 語句被讀取時,只被擴充了一次;而且,那時的 LIST 變數是空的。因此,我們真正執行的 FOR 迴圈是:
for %i in (*) do set LIST= %i
這個迴圈繼續將 LIST 設成找到的最後一個檔案。
延遲環境變數擴充允許您使用一個不同的字元(驚歎號)在執行時間擴充環境變數。如果延遲的變數擴充被啟用,可以將上面例子寫成以下所示,以達到預期效果:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "!VAR!" == "after" @echo If you see this, it worked
)
set LIST=
for %i in (*) do set LIST=!LIST! %i
Echo %LIST%
自動變數
如果命令副檔名被啟用,有幾個動態環境變數可以被擴充套件,但不會出現在 SET 顯示的變數列表中。每次變數數值被擴充套件時,這些變數數值都會被動態計算。如果使用者用這些名稱中任何一個定義變數,那個定義會替代下面描述的動態定義:
顯示、設定或刪除 cmd.exe 環境變數。
語法: SET [variable=[string]]
SET [[/a [expression]] [/p [variable=]] string] variable 指定環境變數名。string 指定要指派給變數的一系列字串。
要顯示當前環境變數,鍵入不帶引數的 SET。
如果命令副檔名被啟用,SET 會如下改變:
僅用一個變數名而不帶等號或者值啟用 SET 命令時,顯示所有字首與提供給SET命令相匹配的變數名及其值。例如:
SET P
會顯示所有以字母 P 打頭的變數。
如果在當前環境中找不到該變數名稱,SET 命令將把 ERRORLEVEL設定成 1。
SET 命令不允許變數名含有等號。
在 SET 命令中添加了兩個新命令列開關:
SET /A expression
SET /P variable=[promptString]
/A 命令列開關
運算子 | 執行的操作 |
---|---|
() | 分組 |
! ~ - | 一元運算子 |
* / % | 算術運算子 |
+ - | 算術運算子 |
<< >> | 邏輯移位 |
& | 按位“與”運算 |
^ | 按位“異或”運算 |
| | 按位“或”運算 |
= *= /= %= += -= &= ^= |= <<= >>= | 賦值 |
, | 表示式分隔符 |
/P 命令列開關
環境變數替換已如下增強:
%PATH:str1=str2% | 會擴充套件 PATH 環境變數,用"str2"代替擴充套件結果中的每個"str1"。要有效地從擴充套件結果中刪除所有的"str1","str2"可以是空的。"str1"可以以星號打頭;在這種情況下,"str1"會從擴充套件結果的開始到 str1 剩餘部分第一次出現的地方,都一直保持相配。也可以為副檔名指定子字串。 |
%PATH:~10,5% | 會擴充套件 PATH 環境變數,然後只使用在擴充套件結果中從第 11 個(偏移量 10)字元開始的五個字元。如果沒有指定長度,則採用預設值,即變數數值的餘數。如果兩個數字(偏移量和長度)都是負數,使用的數字則是環境變數數值長度加上指定的偏移量或長度。 |
%PATH:~-10% | 會提取 PATH 變數的最後十個字元。 |
%PATH:~0,-2% | 會提取 PATH 變數的所有字元,除了最後兩個。 |
set | 顯示目前所有可用的變數,包括系統變數和自定義的變數 |
echo %SystemDrive% | 顯示系統盤碟符。系統變數可以直接引用 |
set p | 顯示所有以p開頭的變數,要是一個也沒有就設errorlevel=1 |
set p=aa1bb1aa2bb2 | 設定變數p,並賦值為 = 後面的字串,即aa1bb1aa2bb2 |
echo %p% | 顯示變數p代表的字串,即aa1bb1aa2bb2 |
echo %p:~6% | 顯示變數p中第6個字元以後的所有字元,即aa2bb2 |
echo %p:~6,3% | 顯示第6個字元以後的3個字元,即aa2 |
echo %p:~0,3% | 顯示前3個字元,即aa1 |
echo %p:~-2% | 顯示最後面的2個字元,即b2 |
echo %p:~0,-2% | 顯示除了最後2個字元以外的其它字元,即aa1bb1aa2b |
echo %p:aa=c% | 用c替換變數p中所有的aa,即顯示c1bb1c2bb2 |
echo %p:aa=% | 將變數p中的所有aa字串置換為空,即顯示1bb12bb2 |
echo %p:*bb=c% | 第一個bb及其之前的所有字元被替換為c,即顯示c1aa2bb2 |
set p=%p:*bb=c% | 設定變數p,賦值為 %p:*bb=c% ,即c1aa2bb2 |
set /a p=39 | 設定p為數值型變數,值為39 |
set /a p=39/10 | 支援運算子,有小數時用去尾法,39/10=3.9,去尾得3,p=3 |
set /a p=p/10 | 用 /a 引數時,在 = 後面的變數可以不加%直接引用 |
set /a p="1&0" | "與"運算,要加引號。其它支援的運算子參見set/? |
set p= | 取消p變數 |
set /p p=請輸入 | 螢幕上顯示"請輸入",並會將輸入的字串賦值給變數p注意這條可以用來取代 choice 命令 |
最後,添加了延遲環境變數擴充套件的支援。該支援總是按預設值被停用,但也可以通過 CMD.EXE 的 /V 命令列開關而被啟用/停用。請參閱 CMD /?。
考慮到讀取一行文字時所遇到的目前擴充的限制時,延遲環境變數擴充是很有用的,而不是執行的時候。以下例子說明直接變數擴充的問題:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "%VAR%" == "after" @echo If you see this, it worked
)
將不會顯示期望的訊息,因為在讀到第一個 IF 語句時,BOTH IF 語句中的 %VAR% 會被代替;原因是: 它包含 IF 的文體,IF 是一個複合語句。所以,複合語句中的 IF 實際上是在比較 "before" 和"after",這兩者永遠不會相等。同樣,以下這個例子也不會達到預期效果:
set LIST=
for %i in (*) do set LIST=%LIST% %i
echo %LIST%
原因是,它不會在目前的目錄中建立一個檔案列表,而只是將LIST 變數設成找到的最後一個檔案。這也是因為 %LIST% 在FOR 語句被讀取時,只被擴充了一次;而且,那時的 LIST 變數是空的。因此,我們真正執行的 FOR 迴圈是:
for %i in (*) do set LIST= %i
這個迴圈繼續將 LIST 設成找到的最後一個檔案。
延遲環境變數擴充允許您使用一個不同的字元(驚歎號)在執行時間擴充環境變數。如果延遲的變數擴充被啟用,可以將上面例子寫成以下所示,以達到預期效果:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "!VAR!" == "after" @echo If you see this, it worked
)
set LIST=
for %i in (*) do set LIST=!LIST! %i
Echo %LIST%
自動變數
如果命令副檔名被啟用,有幾個動態環境變數可以被擴充套件,但不會出現在 SET 顯示的變數列表中。每次變數數值被擴充套件時,這些變數數值都會被動態計算。如果使用者用這些名稱中任何一個定義變數,那個定義會替代下面描述的動態定義:
自動變數 | 說明 |
---|---|
%CD% | 擴充套件到當前目錄字串。 |
%DATE% | 用跟 DATE 命令同樣的格式擴充套件到當前日期。 |
%TIME% | 用跟 TIME 命令同樣的格式擴充套件到當前時間。 |
%RANDOM% | 擴充套件到 0 和 32767 之間的任意十進位制數字。 |
%ERRORLEVEL% | 擴充套件到當前 ERRORLEVEL 數值。 |
%CMDEXTVERSION% | 擴充套件到當前命令處理器副檔名版本號。 |
%CMDCMDLINE% | 擴充套件到呼叫命令處理器的原始命令列。 |