#Requires -Version 2.0
[CmdletBinding()]
Param(
[Parameter()] [string] $MyParam = $null
)
if($MyParam -eq $null) {
Write-Host 'works'
} else {
Write-Host 'does not work'
}
Les sorties "ne fonctionnent pas" => on dirait que les chaînes sont converties de null en chaîne vide implicitement? Pourquoi? Et comment tester si une chaîne est vide ou vraiment $ null? Ce devrait être deux valeurs différentes!
D'accord, j'ai trouvé la réponse @ https://www.codykonior.com/2013/10/17/checking-for-null-in-powershell/
En supposant:
Param(
[string] $stringParam = $null
)
Et le paramètre n'a pas été spécifié (utilise la valeur par défaut):
# will NOT work
if ($null -eq $stringParam)
{
}
# WILL work:
if ($stringParam -eq "" -and $stringParam -eq [String]::Empty)
{
}
Alternativement, vous pouvez spécifier un type null spécial:
Param(
[string] $stringParam = [System.Management.Automation.Language.NullString]::Value
)
Dans ce cas, le $null -eq $stringParam
fonctionnera comme prévu.
Bizarre!
Vous devrez utiliser l'attribut AllowNull
si vous souhaitez autoriser $null
pour les paramètres de chaîne:
[CmdletBinding()]
Param (
[Parameter()]
[AllowNull()]
[string] $MyParam
)
Et notez que vous devez utiliser $ null sur le côté gauche de la comparaison :
if ($null -eq $MyParam)
si vous voulez que cela fonctionne de façon prévisible
en voyant de nombreuses comparaisons d'égalité avec [String] :: Empty, vous pouvez utiliser les méthodes statiques [String] :: IsNullOrWhiteSpace ou [String] :: IsNullOrEmpty, comme les suivantes:
param(
[string]$parameter = $null
)
# we know this is false
($null -eq $parameter)
[String]::IsNullOrWhiteSpace($parameter)
[String]::IsNullOrEmpty($parameter)
('' -eq $parameter)
("" -eq $parameter)
ce qui donne:
PS C:\...> .\foo.ps1
False
True
True
True
True
Faites simplement pas déclarez le type du paramètre si vous voulez qu'une valeur $ null reste:
Param(
$stringParam
)
(Aucune des autres solutions n'a fonctionné pour moi lors de la déclaration du type.)
Il semble donc qu'une valeur par défaut de $null
pour les paramètres de type [string]
par défaut, une chaîne vide, quelle qu'en soit la raison.
Option 1
if ($stringParam) { ... }
Option 2
if ($stringParam -eq "") { ... }
Option 3
if ($stringParam -eq [String]::Empty) { ... }