about_Booleans
簡単な説明
ブール式の評価方法について説明します。
長い説明
PowerShell では、任意の型を ブール値として暗黙的に処理できます。 PowerShell が他の型を ブール 値に変換するために使用するルールを理解しておくことが重要です。
スカラー型からの変換
スカラー型は、一度に 1 つの値のみを保持できるアトミック数量です。 次の型は に評価されます $false
。
- や などの
''
空の文字列""
- Null 値 ( など)
$null
- の値を持つ任意の数値型
0
例 :
PS> $false -eq ''
True
PS> if ("") { $true } else { $false }
False
PS> if ($null) { $true } else { $false }
False
PS> if ([int]0) { $true } else { $false }
False
PS> if ([double]0.0) { $true } else { $false }
False
次の型は に評価されます $true
。
- 空でない文字列
- その他のコレクション以外の型のインスタンス
例 :
# a non-collection type
PS> [bool]@{value = 0}
True
# non-empty strings
PS> if ('hello') { $true } else { $false }
True
PS> [bool]'False'
True
これは 、明示的な文字列解析とは異なります。
PS> [bool]::Parse('false')
False
PS> [bool]::Parse('True')
True
PS> [bool]::Parse('Not True')
MethodInvocationException: Exception calling "Parse" with "1" argument(s):
"String 'Not True' was not recognized as a valid Boolean."
コレクション型からの変換
配列は、PowerShell で最も一般的なコレクション型です。 これらの規則は、 IList インターフェイスを実装するコレクションに似た型に適用されます。
- 空のコレクションは常に
$false
- コマンドからの出力がないことを示す特殊な null 値は、
[System.Management.Automation.Internal.AutomationNull]::Value
常に$false
です。 - 単一要素のコレクションは、1 つの要素と唯一の要素の ブール 値に評価されます。
- 1 つ以上の要素を持つコレクションは常に
$true
です。
例 :
# Empty collections
PS> [bool]@()
False
PS> [bool](Get-ChildItem | Where-Object Name -eq 'Non-existent-File.txt')
False
# Single-element collections
PS> $a = @(0)
PS> [bool]$a
False
PS> $b = @(1)
PS> [bool]$b
True
# Multi-element collections
PS> $c = @(0,0)
PS> [bool]$c
True