Share via


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 として評価します。 が true の場合 <test1> は が <statement list 1> 実行され、PowerShell は ステートメントを If 終了します。 が false の場合 <test1> 、PowerShell は条件ステートメントで指定された条件を <test2> 評価します。

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

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

複数 Elseif のステートメントを使用して、一連の条件付きテストを連結できます。 そのため、各テストは、前のすべてのテストが false の場合にのみ実行されます。 多数Elseifのステートメントを含むステートメントをIf作成する必要がある場合は、代わりに 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.")
}

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

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"

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

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

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

こちらもご覧ください