Set-Variable
設定變數的值。 如果其中一個具有要求的名稱不存在,則建立變數。
語法
Default (預設值)
Set-Variable
[-Name] <String[]>
[[-Value] <Object>]
[-Include <String[]>]
[-Exclude <String[]>]
[-Description <String>]
[-Option <ScopedItemOptions>]
[-Force]
[-Visibility <SessionStateEntryVisibility>]
[-PassThru]
[-Scope <String>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Description
Set-Variable Cmdlet 會將值指派給指定的變數,或變更目前的值。 如果變數不存在,Cmdlet 會建立它。
範例
範例 1:設定變數並取得其值
這些命令會將 $desc 變數的值設定為 A description,然後取得變數的值。
Set-Variable -Name "desc" -Value "A description"
Get-Variable -Name "desc"
Name Value
---- -----
desc A description
範例 2:設定全域只讀變數
此範例會建立全域只讀變數,其中包含系統上的所有進程,然後顯示變數的所有屬性。
Set-Variable -Name "processes" -Value (Get-Process) -Option Constant -Scope Global -Description "All processes" -PassThru |
Format-List -Property *
命令會使用 Set-Variable Cmdlet 來建立變數。 它會使用 PassThru 參數來建立代表新變數的物件,並使用管線運算符 (|) 將對象傳遞至 Format-List Cmdlet。 它會使用 的 Format-List 參數,並將值全部 (*) 顯示新建立變數的所有屬性。
值 (Get-Process)括在括弧中,以確保在儲存在變數之前先執行。 否則,變數會包含 Get-Process字組。
範例 3:瞭解公用變數與私用變數
此範例示範如何將變數的可見性變更為 Private。 此變數可由具有必要許可權的腳本讀取和變更,但使用者看不到此變數。
New-Variable -Name "counter" -Visibility Public -Value 26
$Counter
26
Get-Variable c*
Name Value
---- -----
Culture en-US
ConsoleFileName
ConfirmPreference High
CommandLineParameters {}
Counter 26
Set-Variable -Name "counter" -Visibility Private
Get-Variable c*
Name Value
---- -----
Culture en-US
ConsoleFileName
ConfirmPreference High
CommandLineParameters {}
$counter
"Cannot access the variable '$counter' because it is a private variable"
.\use-counter.ps1
#Commands completed successfully.
此命令示範如何將變數的可見性變更為 Private。 此變數可由具有必要許可權的腳本讀取和變更,但使用者看不到此變數。
參數
-Confirm
在執行 Cmdlet 之前,提示您進行確認。
參數屬性
| 類型: | SwitchParameter |
| 預設值: | False |
| 支援萬用字元: | False |
| 不要顯示: | False |
| 別名: | cf |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Description
指定變數的描述。
參數屬性
| 類型: | String |
| 預設值: | None |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Exclude
指定此 Cmdlet 從作業中排除的項目列表。 此參數的值對 路徑 參數進行限定。 輸入路徑元素或模式,例如 *.txt。
允許使用通配符。
參數屬性
| 類型: | String[] |
| 預設值: | None |
| 支援萬用字元: | True |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Force
可讓您建立名稱與現有唯讀變數相同的變數,或變更只讀變數的值。
根據預設,您可以覆寫變數,除非變數具有選項值 ReadOnly 或 Constant。 如需詳細資訊,請參閱 Option 參數。
參數屬性
| 類型: | SwitchParameter |
| 預設值: | False |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Include
指定此 Cmdlet 包含在作業中的項目陣列。 此參數的值用來說明 Name 參數。 輸入名稱或名稱模式,例如 c*。 允許使用通配符。
參數屬性
| 類型: | String[] |
| 預設值: | None |
| 支援萬用字元: | True |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Name
指定變數名稱。
參數屬性
| 類型: | String[] |
| 預設值: | None |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | 0 |
| 必要: | True |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | True |
| 來自剩餘引數的值: | False |
-Option
指定變數 Options 屬性的值。
有效值為:
-
None:未設定任何選項。 (None為預設值。 -
ReadOnly:可以刪除。 除非使用 Force 參數,否則無法變更。 -
Constant:無法刪除或變更。 只有在您建立變數時,Constant才有效。 您無法將現有變數的選項變更為Constant。 -
Private:變數只能在目前的範圍內使用。 -
AllScope:變數會複製到任何已建立的新範圍。
這些值會定義為旗標型列舉。 您可以將多個值結合在一起,以使用此參數來設定多個旗標。 這些值可以傳遞至 Option 參數做為值的陣列,或是這些值的逗號分隔字串。 Cmdlet 會使用二進位 OR 作業來合併值。 將值以陣列的形式傳遞是最簡單的選擇,還可以讓您在使用 Tab 鍵時自動完成值。
參數屬性
| 類型: | ScopedItemOptions |
| 預設值: | None |
| 接受的值: | None, ReadOnly, Constant, Private, AllScope, Unspecified |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-PassThru
傳回代表新變數的物件。 根據預設,此 Cmdlet 不會產生任何輸出。
參數屬性
| 類型: | SwitchParameter |
| 預設值: | False |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Scope
指定變數的範圍。此參數可接受的值為:
GlobalLocalScriptPrivate- 相對於目前範圍的數位(0 到範圍的數目,其中0是目前的範圍,1是其父系)。
Local 是預設值。
如需詳細資訊,請參閱 about_Scopes。
參數屬性
| 類型: | String |
| 預設值: | Local |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Value
指定變數的值。
參數屬性
| 類型: | Object |
| 預設值: | None |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | 1 |
| 必要: | False |
| 來自管線的值: | True |
| 來自管線按屬性名稱的值: | True |
| 來自剩餘引數的值: | False |
-Visibility
判斷變數是否顯示在建立該變數的會話之外。 此參數的設計目的是要用於將傳遞給其他使用者的腳本和命令中。
有效值為:
-
Public:可見變數。 (Public為預設值。 -
Private:變數不可見。
當變數為私用時,它不會出現在變數清單中,例如 Get-Variable所傳回的變數,或顯示在 變數: 磁碟驅動器中。 讀取或變更私用變數值的命令會傳回錯誤。 不過,如果使用者在定義變數的會話中寫入命令,則可以執行使用私用變數的命令。
參數屬性
| 類型: | SessionStateEntryVisibility |
| 預設值: | Public |
| 接受的值: | Public, Private |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-WhatIf
顯示 Cmdlet 執行時會發生什麼事。 指令未執行。
參數屬性
| 類型: | SwitchParameter |
| 預設值: | False |
| 支援萬用字元: | False |
| 不要顯示: | False |
| 別名: | 無線 |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
CommonParameters
此 Cmdlet 支援一般參數:-Debug、-ErrorAction、-ErrorVariable、-InformationAction、-InformationVariable、-OutBuffer、-OutVariable、-PipelineVariable、-ProgressAction、-Verbose、-WarningAction 和 -WarningVariable。 如需詳細資訊,請參閱 about_CommonParameters。
輸入
Object
您可以使用管線將代表變數值的物件傳送至這個 Cmdlet。
輸出
None
根據預設,此 Cmdlet 不會傳回任何輸出。
PSVariable
當您使用 PassThru 參數時,這個 Cmdlet 會傳回代表新變數或已變更變數的 PSVariable 物件。
備註
PowerShell 包含下列 Set-Variable的別名:
- 所有平臺:
setsv