about_Parameters_Default_Values
Short description
Describes how to set custom default values for cmdlet parameters, advanced functions, and scripts.
Long description
The $PSDefaultParameterValues
preference variable lets you specify custom
default parameter values for any cmdlet, advanced function, or script that uses
the CmdletBinding attribute. The defined values are used unless you specify
other values on the command line.
This feature is useful in the following scenarios:
- specifying the same parameter value every time you use the command
- specifying a particular parameter value that's difficult to remember, such as an email server name or project GUID
The $PSDefaultParameterValues
variable has no default value. To save the
settings for use in future sessions, add the variable assignment to your
PowerShell profile.
$PSDefaultParameterValues
was introduced in PowerShell 3.0.
Syntax
The $PSDefaultParameterValues
variable is an object type of
System.Management.Automation.DefaultParameterDictionary. The
DefaultParameterDictionary type is a hashtable with some extra validation
for the format of the keys. The hashtable contains key-value pairs where:
- the key has the format
CommandName:ParameterName
- the value is default value for the parameter or a ScriptBlock that returns the default value
For the key, the CommandName must be the name of a cmdlet, advanced
function, or script file that uses the CmdletBinding attribute. The script
name must match the name as reported by
(Get-Command -Name .\script.ps1).Name
.
Note
PowerShell doesn't prevent you from specifying an alias for the CommandName. However, there are cases where the definition is ignored or causes an error. You should avoid defining default values for command aliases.
The value can be an object of a type that's compatible with the parameter or a ScriptBlock that returns such a value. When the value is a script block, PowerShell evaluates the script block and uses the result for the parameter value. If the specified parameter expects a ScriptBlock type, you must enclose the value in another set of braces. When PowerShell evaluates the outer ScriptBlock, the result is the inner ScriptBlock. The inner ScriptBlock becomes the new default parameter value.
For example:
$PSDefaultParameterValues = @{
'Invoke-Command:ScriptBlock' = { {Get-Process} }
}
Examples
Use the Add()
and Remove()
methods to add or remove a specific key-value
pair from $PSDefaultParameterValues
without overwriting other existing
key-value pairs.
$PSDefaultParameterValues.Add('CmdletName:ParameterName', 'DefaultValue')
$PSDefaultParameterValues.Remove('CmdletName:ParameterName')
Use indexing or member access to change the value of an existing key-value pair. For example:
$PSDefaultParameterValues.'CommandName:ParameterName'='DefaultValue2'
$PSDefaultParameterValues['CommandName:ParameterName']='DefaultValue1'
Assign values to $PSDefaultParameterValues
To define default values for cmdlet parameters, assign a hashtable containing
the appropriate key-value pairs to the $PSDefaultParameterValues
variable.
The hashtable can contain multiple key-value pairs. This example sets default
values for the Send-MailMessage:SmtpServer
and Get-WinEvent:LogName
keys.
$PSDefaultParameterValues = @{
'Send-MailMessage:SmtpServer'='Server123'
'Get-WinEvent:LogName'='Microsoft-Windows-PrintService/Operational'
}
The cmdlet and parameter names can contain wildcard characters. Use $true
and
$false
to set values for switch parameters, such as Verbose. This example
sets the common parameter Verbose to $true
for all commands.
$PSDefaultParameterValues = @{'*:Verbose'=$true}
If a parameter accepts multiple values, you can provide multiple default values
using an array. This example sets the default value of the
Invoke-Command:ComputerName
key to an array containing the string values
Server01
and Server02
.
$PSDefaultParameterValues = @{
'Invoke-Command:ComputerName' = 'Server01', 'Server02'
}
View defined values
Consider the following definition of $PSDefaultParameterValues
:
$PSDefaultParameterValues = @{
'Send-MailMessage:SmtpServer' = 'Server123'
'Get-WinEvent:LogName' = 'Microsoft-Windows-PrintService/Operational'
'Get-*:Verbose' = $true
}
You can view the defined values by entering $PSDefaultParameterValues
at the
command prompt.
PS> $PSDefaultParameterValues
Name Value
---- -----
Get-WinEvent:LogName Microsoft-Windows-PrintService/Operational
Get-*:Verbose True
Send-MailMessage:SmtpServer Server123
You can use indexing or member access to get a specific value.
PS> $PSDefaultParameterValues['Send-MailMessage:SmtpServer'] # index notation
Server123
PS> $PSDefaultParameterValues.'Get-*:Verbose' # member access notation
True
Use a script block for the default value
You can use a script block to specify different default values for a parameter under different conditions. PowerShell evaluates the script block and uses the result as the default parameter value.
The Format-Table:AutoSize
key sets that switch parameter to a default value
of $true
The if
statement contains a condition that the $Host.Name
must
be ConsoleHost
.
$PSDefaultParameterValues = @{
'Format-Table:AutoSize' = { if ($Host.Name -eq 'ConsoleHost'){$true} }
}
If a parameter accepts a ScriptBlock value, enclose the ScriptBlock in another set of braces. When PowerShell evaluates the outer ScriptBlock, the result is the inner ScriptBlock. The inner ScriptBlock becomes the new default parameter value.
$PSDefaultParameterValues = @{
'Invoke-Command:ScriptBlock' = { {Get-EventLog -Log System} }
}
Add values to an existing $PSDefaultParameterValues
variable
To add a value to $PSDefaultParameterValues
, use the Add()
method. Adding a
value doesn't affect the hashtable's existing values. Use a comma (,
) to
separate the key from the value.
$PSDefaultParameterValues.Add('Get-Process:Name', 'PowerShell')
The hashtable created in the prior example is updated with a new key-value pair.
PS> $PSDefaultParameterValues
Name Value
---- -----
Get-Process:Name PowerShell
Get-WinEvent:LogName Microsoft-Windows-PrintService/Operational
Get-*:Verbose True
Send-MailMessage:SmtpServer Server123
Remove a value from $PSDefaultParameterValues
To remove a value from $PSDefaultParameterValues
, use the Remove()
method.
Removing a value doesn't affect the hashtable's existing values.
This example removes the key-value pair that was added in the previous example.
PS> $PSDefaultParameterValues.Remove('Get-Process:Name')
PS> $PSDefaultParameterValues
Name Value
---- -----
Get-WinEvent:LogName Microsoft-Windows-PrintService/Operational
Get-*:Verbose True
Send-MailMessage:SmtpServer Server123
Change a value in $PSDefaultParameterValues
Use indexing or member access to change the default value of an existing
key-value pair. In this example, the default value for the
Send-MailMessage:SmtpServer
key is changed to a new value of ServerXYZ.
PS> $PSDefaultParameterValues['Send-MailMessage:SmtpServer']='ServerXYZ'
PS> $PSDefaultParameterValues
Name Value
---- -----
Get-WinEvent:LogName Microsoft-Windows-PrintService/Operational
Get-*:Verbose True
Send-MailMessage:SmtpServer ServerXYZ
Disable or re-enable $PSDefaultParameterValues
You can temporarily disable and then re-enable $PSDefaultParameterValues
.
Disabling $PSDefaultParameterValues
is useful if you're running scripts that
need different default parameter values.
To disable $PSDefaultParameterValues
, add a key of Disabled
with a value of
$true
. The values in $PSDefaultParameterValues
are preserved, but aren't
used.
PS> $PSDefaultParameterValues.Add('Disabled', $true)
PS> $PSDefaultParameterValues
Name Value
---- -----
Disabled True
Get-WinEvent:LogName Microsoft-Windows-PrintService/Operational
Get-*:Verbose True
Send-MailMessage:SmtpServer ServerXYZ
To re-enable $PSDefaultParameterValues
, remove the Disabled
key or change
the value of the Disabled
key to $false
.
PS> $PSDefaultParameterValues.Disabled = $false
PS> $PSDefaultParameterValues
Name Value
---- -----
Disabled False
Get-WinEvent:LogName Microsoft-Windows-PrintService/Operational
Get-*:Verbose True
Send-MailMessage:SmtpServer ServerXYZ