Set-Alias
在目前的PowerShell會話中建立或變更 Cmdlet 或其他命令的別名。
語法
Default (預設值)
Set-Alias
[-Name] <string>
[-Value] <string>
[-Description <string>]
[-Option <ScopedItemOptions>]
[-PassThru]
[-Scope <string>]
[-Force]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Description
Set-Alias Cmdlet 會建立或變更 Cmdlet 或命令的別名,例如函式、腳本、檔案或其他可執行檔。 別名是參考 Cmdlet 或命令的替代名稱。 例如,sal 是 Set-Alias Cmdlet 的別名。 如需詳細資訊,請參閱 about_Aliases。
Cmdlet 可以有多個別名,但別名只能與一個 Cmdlet 相關聯。 您可以使用 Set-Alias 將現有的別名重新指派給另一個 Cmdlet,或變更別名的屬性,例如描述。
Set-Alias 所建立或變更的別名不是永久性的,而且只能在目前的PowerShell工作階段期間使用。 關閉 PowerShell 工作階段時,會移除別名。
範例
範例 1:建立 Cmdlet 的別名
此命令會在目前的 PowerShell 工作階段中建立 Cmdlet 的別名。
PS> Set-Alias -Name list -Value Get-ChildItem
PS> Get-Alias -Name list
CommandType Name
----------- ----
Alias list -> Get-ChildItem
Set-Alias Cmdlet 會在目前的 PowerShell 工作階段中建立別名。
Name 參數會指定別名的名稱,list。
Value 參數會指定別名執行的 Cmdlet。
若要執行別名,請在PowerShell命令行上輸入 list。
範例 2:將現有的別名重新指派給不同的 Cmdlet
此命令會重新指派現有的別名,以執行不同的 Cmdlet。
PS> Get-Alias -Name list
CommandType Name
----------- ----
Alias list -> Get-ChildItem
PS> Set-Alias -Name list -Value Get-Location
PS> Get-Alias -Name list
CommandType Name
----------- ----
Alias list -> Get-Location
Get-Alias Cmdlet 會使用 Name 參數來顯示 list 別名。
list 別名與 Get-ChildItem Cmdlet 相關聯。 執行 list 別名時,會顯示目前目錄中的專案。
Set-Alias Cmdlet 會使用 Name 參數來指定 list 別名。
Value 參數會將別名與 Get-Location Cmdlet 產生關聯。
Get-Alias Cmdlet 會使用 Name 參數來顯示 list 別名。
list 別名與 Get-Location Cmdlet 相關聯。 執行 list 別名時,會顯示目前目錄的位置。
範例 3:建立和變更唯讀別名
此命令會建立唯讀別名。 唯讀選項可防止對別名進行非預期的變更。 若要變更或刪除唯讀別名,請使用 Force 參數。
Set-Alias -Name loc -Value Get-Location -Option ReadOnly -PassThru |
Format-List -Property *
DisplayName : loc -> Get-Location
Definition : Get-Location
Options : ReadOnly
Description :
Name : loc
CommandType : Alias
$Parameters = @{
Name = 'loc'
Value = (Get-Location)
Option = 'ReadOnly'
Description = 'Displays the current directory'
Force = $true
PassThru = $true
}
Set-Alias @Parameters | Format-List -Property *
DisplayName : loc -> Get-Location
Definition : Get-Location
Options : ReadOnly
Description : Displays the current directory
Name : loc
CommandType : Alias
Set-Alias Cmdlet 會在目前的 PowerShell 工作階段中建立別名。
Name 參數會指定別名的名稱,loc。
Value 參數會指定別名執行 Get-Location Cmdlet。
Option 參數會指定 readOnly 值。
PassThru 參數代表別名物件,並將物件向下傳送至 Format-List Cmdlet。
Format-List 使用 Property 參數搭配星號(*),以便顯示每個屬性。 範例輸出會顯示這些屬性的部分清單。
loc 別名會隨著新增兩個參數而變更。
描述 新增文字來說明別名的目的。 需要 Force 參數,因為 loc 別名是唯讀的。 如果未使用 Force 參數,則變更會失敗。
範例 4:建立可執行文件的別名
此範例會在本機計算機上建立可執行文件的別名。
PS> Set-Alias -Name np -Value C:\Windows\notepad.exe
PS> Get-Alias -Name np
CommandType Name
----------- ----
Alias np -> notepad.exe
Set-Alias Cmdlet 會在目前的 PowerShell 工作階段中建立別名。
Name 參數會指定別名的名稱,np。
Value 參數會指定路徑和應用程式名稱 C:\Windows\notepad.exe。
Get-Alias Cmdlet 會使用 Name 參數來顯示 np 別名與 notepad.exe相關聯。
若要執行別名,請在 PowerShell 命令行上輸入 np 以開啟 notepad.exe。
範例 5:使用參數建立命令的別名
此範例示範如何使用參數將別名指派給命令。
您可以建立 Cmdlet 的別名,例如 Set-Location。 您無法為具有參數和值的指令建立別名,例如 Set-Location -Path C:\Windows\System32。 若要建立命令的別名,請建立包含 命令的函式,然後建立函式的別名。 如需詳細資訊,請參閱 about_Functions。
Function CD32 {Set-Location -Path C:\Windows\System32}
Set-Alias -Name Go -Value CD32
會建立名為 CD32 的函式。 函式會使用 Set-Location Cmdlet 搭配 Path 參數來指定目錄,C:\Windows\System32。
Set-Alias Cmdlet 會在目前的 PowerShell 工作階段中建立函式的別名。
Name 參數會指定別名的名稱,Go。
Value 參數會指定函式的名稱,CD32。
若要執行別名,請在PowerShell命令行上輸入 Go。
CD32 函式會執行並變更目錄 C:\Windows\System32。
範例 6:現有別名的更新選項
此範例示範如何使用 Option 參數來指派多個選項。
從上一個範例繼續,將別名 Go 設定為 ReadOnly,並 Private。
Set-Alias -Name Go -Option ReadOnly, Private
別名 Go 應該已經存在。 執行命令之後,在不使用 Force 參數的情況下,就無法變更別名,而且只能在目前的範圍中使用。
參數
-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 |
-Force
使用 Force 參數來變更或刪除 Option 參數設定為 ReadOnly的別名。
Force 參數無法變更或刪除別名,並將 Option 參數設定為 常數。
參數屬性
| 類型: | SwitchParameter |
| 預設值: | False |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Name
指定新別名的名稱。 別名名稱可以包含英數位元和連字元。 別名名稱不能是數值,例如123。
參數屬性
| 類型: | String |
| 預設值: | None |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | 0 |
| 必要: | True |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | True |
| 來自剩餘引數的值: | False |
-Option
設定別名的 Option 屬性值。
ReadOnly 和 Constant 等值可保護別名免於非預期的變更。 若要查看工作階段中所有別名的 Option 屬性,請輸入 Get-Alias | Format-Table -Property Name, Options -Autosize。
此參數可接受的值如下:
-
AllScope- 別名會複製到任何已建立的新範圍。 -
Constant- 無法變更或刪除。 -
None- 未設定任何選項,且為預設值。 -
Private- 別名僅適用於目前的範圍。 -
ReadOnly- 除非使用 Force 參數,否則無法變更或刪除。 Unspecified
這些值會定義為旗標型列舉。 您可以將多個值結合在一起,以使用此參數來設定多個旗標。 這些值可以傳遞至 Option 參數做為值的陣列,或是這些值的逗號分隔字串。 Cmdlet 會使用二進位 OR 作業來結合值。 將值以陣列的形式傳遞是最簡單的選擇,還可以讓您在使用 Tab 鍵時自動完成值。
參數屬性
| 類型: | ScopedItemOptions |
| 預設值: | None |
| 接受的值: | AllScope, Constant, None, Private, ReadOnly, Unspecified |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-PassThru
傳回代表別名的物件。 使用格式 Cmdlet,例如 Format-List 來顯示物件。 根據預設,Set-Alias 不會產生任何輸出。
參數屬性
| 類型: | SwitchParameter |
| 預設值: | None |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Scope
指定這個別名的有效範圍。 預設值為 Local。 如需詳細資訊,請參閱 about_Scopes。
可接受的值如下:
GlobalLocalPrivateNumbered scopesScript
參數屬性
| 類型: | String |
| 預設值: | Local |
| 接受的值: | Global, Local, Private, Numbered scopes, Script |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | Named |
| 必要: | False |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | False |
| 來自剩餘引數的值: | False |
-Value
指定別名執行之 Cmdlet 或命令的名稱。 Value 參數是別名 Definition 屬性。
參數屬性
| 類型: | String |
| 預設值: | None |
| 支援萬用字元: | False |
| 不要顯示: | False |
參數集
(All)
| Position: | 1 |
| 必要: | True |
| 來自管線的值: | False |
| 來自管線按屬性名稱的值: | True |
| 來自剩餘引數的值: | False |
-WhatIf
顯示 Cmdlet 執行時會發生什麼事。 該 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。
輸入
None
您不能將物件透過管道傳送到此 Cmdlet。
輸出
None
根據預設,此 Cmdlet 不會傳回任何輸出。
AliasInfo
當您使用 PassThru 參數時,這個 Cmdlet 會傳回代表別名的 AliasInfo 物件。
備註
PowerShell 包含下列 Set-Alias的別名:
- 所有平臺:
sal
PowerShell 包含每個 PowerShell 工作階段中可用的內建別名。
Get-Alias Cmdlet 會顯示 PowerShell 工作階段中可用的別名。
若要建立別名,請使用 cmdlet Set-Alias 或 New-Alias。 在 PowerShell 6 中,若要刪除別名,請使用 Remove-Alias Cmdlet。
Remove-Item 會接受回溯相容性,例如使用舊版 PowerShell 建立的腳本。 使用命令,例如 Remove-Item -Path Alias:aliasname。
若要建立每個 PowerShell 工作階段中可用的別名,請將它新增至您的 PowerShell 配置檔。 如需詳細資訊,請參閱 about_Profiles。
您可以藉由執行匯出和匯入,將別名儲存並重複使用在另一個 PowerShell 會話中。 若要將別名儲存至檔案,請使用 Export-Alias。 若要將已儲存的別名新增至新的 PowerShell 工作階段,請使用 Import-Alias。