New-Variable
建立新變數。
語法
New-Variable
[-Name] <String>
[[-Value] <Object>]
[-Description <String>]
[-Option <ScopedItemOptions>]
[-Visibility <SessionStateEntryVisibility>]
[-Force]
[-PassThru]
[-Scope <String>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Description
Cmdlet 會在 New-Variable
PowerShell 中建立新的變數。 您可以在建立變數時將值指派給變數,或在建立后指派或變更值。
您可以使用 New-Variable
的參數來設定變數的屬性、設定變數的範圍,以及判斷變數是公用還是私用的。
一般而言,您可以輸入變數名稱和其值來建立新的變數,例如 $Var = 3
,但您可以使用 New-Variable
Cmdlet 來使用其參數。
範例
範例 1:建立變數
New-Variable days
此命令會建立名為 days 的新變數。 您不需要輸入 Name 參數。
範例 2:建立變數併為其指派值
New-Variable -Name "zipcode" -Value 98033
此命令會建立名為 zipcode 的變數,並將值指派為 98033。
範例 3:使用 ReadOnly 選項建立變數
PS C:\> New-Variable -Name Max -Value 256 -Option ReadOnly
PS C:\> New-Variable -Name max -Value 1024
New-Variable : A variable with name 'max' already exists.
At line:1 char:1
+ New-Variable -Name max -Value 1024
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : ResourceExists: (max:String) [New-Variable], SessionStateException
+ FullyQualifiedErrorId : VariableAlreadyExists,Microsoft.PowerShell.Commands.NewVariableCommand
PS C:\> New-Variable -Name max -Value 1024 -Force
此範例示範如何使用 ReadOnly
的 選項 New-Variable
來保護變數不受覆寫。
第一個命令會建立名為 Max 的新變數,並將其值設定為 256。 它會使用 Option 參數搭配 的值 ReadOnly
。
第二個命令會嘗試建立具有相同名稱的第二個變數。 此命令會傳回錯誤,因為變數上已設定唯讀選項。
第三個命令會 使用 Force 參數覆寫變數上的唯讀保護。 在此情況下,建立具有相同名稱的新變數的命令會成功。
範例 4:將多個選項指派給變數
New-Variable -Name 'TestVariable' -Value 'Test Value' -Option AllScope,Constant
此範例會建立變數並指派 AllScope
和 Constant
選項,讓變數可在目前的範圍中使用,以及建立且無法變更或刪除的任何新範圍。
範例 5:建立私用變數
此命令示範模組中私用變數的行為。 模組包含 Get-Counter
Cmdlet,其具有名為 Counter 的私人變數。 此命令會 使用 Visibility 參數搭配 Private 值來建立變數。
PS C:\> New-Variable -Name counter -Visibility Private
#Effect of private variable in a module.
PS C:\> Get-Variable c*
Name Value
---- -----
Culture en-US
ConsoleFileName
ConfirmPreference High
CommandLineParameters {}
PS C:\> $counter
"Cannot access the variable '$counter' because it is a private variable"
At line:1 char:1
+ $counter
+ ~~~~~~~~
+ CategoryInfo : PermissionDenied: (counter:String) [], SessionStateException
+ FullyQualifiedErrorId : VariableIsPrivate
PS C:\> Get-Counter
Name Value
---- -----
Counter1 3.1415
...
範例輸出會顯示私用變數的行為。 載入模組的使用者無法檢視或變更 Counter 變數的值,但模組中的命令可以讀取和變更 Counter 變數。
範例 6:建立具有空格的變數
此範例示範可以建立具有空格的變數。 您可以使用 Cmdlet 或直接使用 Get-Variable
大括弧分隔變數來存取變數。
PS C:\> New-Variable -Name 'with space' -Value 'abc123xyz'
PS C:\> Get-Variable -Name 'with space'
Name Value
---- -----
with space abc123xyz
PS C:\> ${with space}
abc123xyz
參數
-Confirm
執行 Cmdlet 之前先提示您確認。
類型: | SwitchParameter |
別名: | cf |
Position: | Named |
預設值: | False |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
-Description
指定變數的描述。
類型: | String |
Position: | Named |
預設值: | None |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
-Force
表示 Cmdlet 會建立名稱與現有唯讀變數相同的變數。
根據預設,除非變數具有 或Constant
的選項值ReadOnly
,否則您可以覆寫變數。 如需詳細資訊,請參閱 Option 參數。
類型: | SwitchParameter |
Position: | Named |
預設值: | None |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
-Name
指定新變數的名稱。
類型: | String |
Position: | 0 |
預設值: | None |
必要: | True |
接受管線輸入: | True |
接受萬用字元: | False |
-Option
指定變數的 Options 屬性值。 此參數可接受的值為:
None
- 未設定任何選項。None
是預設值。ReadOnly
- 可以刪除。 除非使用 Force 參數,否則無法變更。Private
- 變數只能在目前的範圍內使用。AllScope
- 變數會複製到任何已建立的新範圍。Constant
- 無法刪除或變更。Constant
只有在您建立變數時才有效。 您無法將現有變數的選項變更為Constant
。
這些值會定義為旗標型列舉。 您可以將多個值結合在一起,以使用此參數來設定多個旗標。 這些值可以傳遞至 Option 參數做為值的陣列,或是這些值的逗號分隔字串。 Cmdlet 會使用二進位 OR 作業來合併值。 將值當做數位傳遞是最簡單的選項,也可讓您在值上使用 Tab 鍵自動完成。
若要檢視工作階段中所有變數的 Options 屬性,請輸入 Get-Variable | Format-Table -Property name, options -AutoSize
。
類型: | ScopedItemOptions |
接受的值: | None, ReadOnly, Constant, Private, AllScope, Unspecified |
Position: | Named |
預設值: | None |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
-PassThru
會傳回 物件,代表您正在使用的專案。 根據預設,此 Cmdlet 不會產生任何輸出。
類型: | SwitchParameter |
Position: | Named |
預設值: | None |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
-Scope
指定新變數的範圍。 此參數可接受的值為:
Global
- 在全域範圍中建立的變數可在PowerShell程式中隨處存取。Local
- 本機範圍是指目前的範圍,視內容而定,這可以是任何範圍。Local
如果未指定 scope 參數,則為預設範圍。Script
- 在腳本範圍中建立的變數只能在腳本檔案中存取,或是在腳本檔案中建立的模組。- 相對於目前範圍的數位(0 到範圍的數目,其中0是目前的範圍,1是其父範圍,2是父範圍的父系等等)。 無法使用負數。
注意
參數也接受的值 Private
。 Private
實際上不是範圍,而是變數的選擇性設定。 不過,搭配這個 Cmdlet 使用 Private
值並不會變更變數的可見性。 如需詳細資訊,請參閱 about_Scopes。
類型: | String |
Position: | Named |
預設值: | None |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
-Value
指定變數的初始值。
類型: | Object |
Position: | 1 |
預設值: | None |
必要: | False |
接受管線輸入: | True |
接受萬用字元: | False |
-Visibility
判斷變數是否顯示在建立該變數的會話之外。 此參數的設計目的是要用於將傳遞給其他使用者的腳本和命令中。 此參數可接受的值為:
Public
- 可見變數。Public
是預設值。Private
- 看不到變數。
當變數為私用時,它不會出現在變數清單中,例如所傳 Get-Variable
回的變數,或在磁碟驅動器的 Variable:
顯示中。 讀取或變更私用變數值的命令會傳回錯誤。 不過,如果使用者在定義變數的會話中寫入命令,則可以執行使用私用變數的命令。
類型: | SessionStateEntryVisibility |
接受的值: | Public, Private |
Position: | Named |
預設值: | None |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
-WhatIf
顯示執行 Cmdlet 後會發生的情況。 未執行 Cmdlet。
類型: | SwitchParameter |
別名: | wi |
Position: | Named |
預設值: | False |
必要: | False |
接受管線輸入: | False |
接受萬用字元: | False |
輸入
您可以使用管線將任何物件傳送至 New-Variable
。
輸出
None
根據預設,此 Cmdlet 不會傳回任何輸出。
當您使用 PassThru 參數時,這個 Cmdlet 會 傳回代表新變數的 PSVariable 物件。
備註
Windows PowerShell 包含下列的 New-Variable
別名:
nv