about_If

概要

1つまたは複数の条件付きテストの結果に基づいてステートメントリストを実行するために使用できる言語コマンドについて説明します。

詳細説明

If指定した条件テストが true と評価された場合に、ステートメントを使用してコードブロックを実行できます。 前のテストがすべて false と評価された場合に実行する1つ以上の条件付きテストを指定することもできます。 最後に、他の条件付きテストが true と評価されなかった場合に実行される追加のコードブロックを指定できます。

構文

次の例は、ステートメントの構文を示してい If ます。

if (<test1>)
    {<statement list 1>}
[elseif (<test2>)
    {<statement list 2>}]
[else
    {<statement list 3>}]

ステートメントを実行すると If 、PowerShell によっ <test1> て条件式が true または false として評価されます。 <test1>が true の場合、が実行され、 <statement list 1> PowerShell によってステートメントが終了し If ます。 <test1>が false の場合、PowerShell は条件付きステートメントによって指定された条件を評価し <test2> ます。

ブール型の評価の詳細については、「 about_Booleans」を参照してください。

<test2>が true の場合、が実行され、 <statement list 2> PowerShell によってステートメントが終了し If ます。 との両方が false と評価された場合 <test1> <test2><statement list 3> コードブロックが実行され、PowerShell は If ステートメントを終了します。

複数のステートメントを使用して Elseif 、一連の条件付きテストをチェーンすることができます。 そのため、各テストは、前のすべてのテストが false の場合にのみ実行されます。 多くのステートメントを含むステートメントを作成する必要がある場合は If Elseif 、代わりに Switch ステートメントを使用することを検討してください。

例 :

最も単純 If なステートメントには1つのコマンドが含まれており、Elseif ステートメントや Else ステートメントは含まれていません。 次の例は、ステートメントの最も単純な形式を示してい If ます。

if ($a -gt 2) {
    Write-Host "The value $a is greater than 2."
}

この例では、$a 変数が2より大きい場合、条件は true に評価され、ステートメントリストが実行されます。 ただし、$a が2以下であるか、または既存の変数ではない場合、 If ステートメントはメッセージを表示しません。

Else ステートメントを追加すると、$a が2以下の場合にメッセージが表示されます。 次の例に示すように、次のようになります。

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.")
}

この例をさらに絞り込むために、$a の値が2に等しい場合に、Elseif ステートメントを使用してメッセージを表示することができます。 次の例に示すように、次のようになります。

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.")
}

三項演算子の構文の使用

PowerShell 7.0 では、三項演算子を使用した新しい構文が導入されました。 C# の三項演算子の構文に従います。

<condition> ? <if-true> : <if-false>

三項演算子は、簡略化されたステートメントと同様に動作し if-else ます。 <condition>式が評価され、結果がブール値に変換されて、次に評価する分岐を決定します。

  • <if-true> 式は、<condition> 式が true の場合に実行されます
  • <if-false> 式は、<condition> 式が false の場合に実行されます

次に例を示します。

$message = (Test-Path $path) ? "Path exists" : "Path not found"

この例で $message は、がを返すと、の値は "Path exists" になり Test-Path $true ます。 Test-Pathがを返す場合 $false 、の値 $message は "Path not found" になります。

$service = Get-Service BITS
$service.Status -eq 'Running' ? (Stop-Service $service) : (Start-Service $service)

この例では、サービスが実行されている場合は停止され、状態が 実行中 でない場合は開始されます。

関連項目