about_If

简短说明

描述可用于基于一个或多个条件测试结果运行语句列表的语言命令。

详细说明

如果指定的条件测试的计算结果为 true,则可以使用 If 语句运行代码块。 如果以前的所有测试的计算结果为 false,还可以指定要运行的一个或多个其他条件测试。 最后,您可以指定一个额外的代码块,如果没有其他先前的条件测试计算结果为 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 语句。 如果两者兼而有之, <test1> 则 AND <test2> EVALUATE 为 false, <statement list 3> 则代码块运行,并且 PowerShell 退出 If 语句。

可以使用多个 Elseif 语句链接一系列条件测试。 因此,仅当所有先前的测试均为 false 时,才会运行每个测试。 如果需要创建包含许多 If 语句的 Elseif 语句,请考虑改用 Switch 语句。

例子:

最简单的 If 语句包含单个命令,不包含任何 Elseif 语句或任何 Else 语句。 以下示例显示了 If 语句的最简单形式:

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

在此示例中,如果 $a 变量大于 2,则条件的计算结果为 true,并且语句 list 将运行。 但是,如果 $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> 表达式为 true,则执行 <condition> 表达式
  • 如果 <if-false> 表达式为 false,则执行 <condition> 表达式

例如:

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

在此示例中,当返回 $trueTest-Path,值为 $message “Path exists” 。 当返回 $falseTest-Path,的$message值为 “Path not found”。

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

在此示例中,如果服务正在运行,则将其停止,如果其状态不是 Running ,则表示已启动。

另请参阅