간단한 설명
하나 이상의 조건부 테스트 결과에 따라 문 목록을 실행하는 데 사용할 수 있는 언어 명령에 대해 설명합니다.
긴 설명
지정된 조건부 테스트가 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> 및 <test2> 모두 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로 평가되고 문 목록이 실행됩니다. 그러나 $a2 작거나 같거나 기존 변수가 아닌 경우 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.")
}
3항 연산자 구문 사용
PowerShell 7.0에서는 3항 연산자를 사용하는 새 구문을 도입했습니다. C# 3항 연산자 구문을 따릅니다.
<condition> ? <if-true> : <if-false>
3항 연산자는 간소화된 if-else 문처럼 동작합니다.
<condition> 식이 계산되고 결과가 부울로 변환되어 다음에 평가해야 하는 분기를 결정합니다.
-
<if-true>식이 true이면<condition>식이 실행됩니다. -
<if-false>식이 false이면<condition>식이 실행됩니다.
다음은 그 예입니다.
$message = (Test-Path $path) ? "Path exists" : "Path not found"
이 예제에서는 $messagePath 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)
이 예제에서 서비스가 실행 중이면 서비스가 중지되고 상태가 실행시작됩니다.
<condition>, <if-true>또는 <if-false> 식이 명령을 호출하는 경우 괄호로 래핑해야 합니다. 그렇지 않은 경우 PowerShell은 <condition> 식에서 명령에 대한 인수 예외를 발생시키고 <if-true> 및 <if-false> 식에 대한 예외를 구문 분석합니다.
예를 들어 PowerShell은 이러한 ternaries에 대한 예외를 발생합니다.
Test-Path .vscode ? Write-Host 'exists' : Write-Host 'not found'
(Test-Path .vscode) ? Write-Host 'exists' : Write-Host 'not found'
(Test-Path .vscode) ? (Write-Host 'exists') : Write-Host 'not found'
Test-Path: A positional parameter cannot be found that accepts argument '?'.
ParserError:
Line |
1 | (Test-Path .vscode) ? Write-Host 'exists' : Write-Host 'not found'
| ~
| You must provide a value expression following the '?' operator.
ParserError:
Line |
1 | (Test-Path .vscode) ? (Write-Host 'exists') : Write-Host 'not found'
| ~
| You must provide a value expression following the ':' operator.
그리고 이 예제에서는 다음을 구문 분석합니다.
(Test-Path .vscode) ? (Write-Host 'exists') : (Write-Host 'not found')
exists