about_If
Korte beschrijving
Beschrijft een taalopdracht die u kunt gebruiken om instructielijsten uit te voeren op basis van de resultaten van een of meer voorwaardelijke tests.
Lange beschrijving
U kunt de If instructie gebruiken om codeblokken uit te voeren als een opgegeven voorwaardelijke test waar oplevert. U kunt ook een of meer aanvullende voorwaardelijke tests opgeven die moeten worden uitgevoerd als alle eerdere tests onwaar evalueren. Ten slotte kunt u een extra codeblok opgeven dat wordt uitgevoerd als er geen andere voorwaardelijke test resulteert in waar.
Syntax
In het volgende voorbeeld ziet u de syntaxis van de If instructie:
if (<test1>)
{<statement list 1>}
[elseif (<test2>)
{<statement list 2>}]
[else
{<statement list 3>}]
Wanneer u een If instructie uitvoert, evalueert PowerShell de <test1> voorwaardelijke expressie als waar of onwaar. Als <test1> dit waar is, <statement list 1> wordt de instructie uitgevoerd en powerShell wordt de If instructie afgesloten. Als <test1> dit onwaar is, evalueert PowerShell de voorwaarde die is opgegeven door de <test2> voorwaardelijke instructie.
Zie about_Booleans voor meer informatie over booleaanse evaluatie.
Als <test2> dit waar is, <statement list 2> wordt de instructie uitgevoerd en powerShell wordt de If instructie afgesloten. Als beide <test1> onwaar <test2> worden geëvalueerd, wordt het <statement list 3> codeblok uitgevoerd en sluit PowerShell de if-instructie af.
U kunt meerdere Elseif instructies gebruiken om een reeks voorwaardelijke tests te koppelen. Dus dat elke test alleen wordt uitgevoerd als alle vorige tests onwaar zijn. Als u een If instructie wilt maken die veel Elseif instructies bevat, kunt u in plaats daarvan een Switch-instructie gebruiken.
Voorbeelden:
De eenvoudigste If instructie bevat één opdracht en bevat geen Elseif-instructies of else-instructies. In het volgende voorbeeld ziet u de eenvoudigste vorm van de If instructie:
if ($a -gt 2) {
Write-Host "The value $a is greater than 2."
}
Als in dit voorbeeld de variabele $a groter is dan 2, resulteert de voorwaarde in waar en wordt de instructielijst uitgevoerd. Als $a echter kleiner dan of gelijk is aan 2 of geen bestaande variabele is, If wordt er geen bericht weergegeven.
Door een Else-instructie toe te voegen, wordt een bericht weergegeven wanneer $a kleiner is dan of gelijk is aan 2. Zoals in het volgende voorbeeld wordt weergegeven:
if ($a -gt 2) {
Write-Host "The value $a is greater than 2."
}
else {
Write-Host ("The value $a is less than or equal to 2," +
" is not created or is not initialized.")
}
Als u dit voorbeeld verder wilt verfijnen, kunt u de Elseif-instructie gebruiken om een bericht weer te geven wanneer de waarde van $a gelijk is aan 2. Zoals in het volgende voorbeeld wordt weergegeven:
if ($a -gt 2) {
Write-Host "The value $a is greater than 2."
}
elseif ($a -eq 2) {
Write-Host "The value $a is equal to 2."
}
else {
Write-Host ("The value $a is less than 2 or" +
" was not created or initialized.")
}
De syntaxis van de ternaire operator gebruiken
PowerShell 7.0 heeft een nieuwe syntaxis geïntroduceerd met behulp van de ternaire operator. Deze volgt de syntaxis van de ternaire C#-operator:
<condition> ? <if-true> : <if-false>
De ternaire operator gedraagt zich als de vereenvoudigde if-else instructie. De <condition> expressie wordt geëvalueerd en het resultaat wordt geconverteerd naar een Booleaanse waarde om te bepalen welke vertakking vervolgens moet worden geëvalueerd:
- De
<if-true>expressie wordt uitgevoerd als de<condition>expressie waar is - De
<if-false>expressie wordt uitgevoerd als de<condition>expressie onwaar is
Bijvoorbeeld:
$message = (Test-Path $path) ? "Path exists" : "Path not found"
In dit voorbeeld is de waarde ' $message Pad bestaat' wanneer Test-Path deze wordt geretourneerd $true. Wanneer Test-Path wordt $falsegeretourneerd, is de waarde van $message 'Pad niet gevonden'.
$service = Get-Service BITS
$service.Status -eq 'Running' ? (Stop-Service $service) : (Start-Service $service)
Als de service wordt uitgevoerd, wordt deze in dit voorbeeld gestopt en als de status niet actief is, wordt deze gestart.