目次
PowerShellでのWhere-Objectコマンドの使い方とは?
今回は、PowerShellでのWhere-Objectコマンドの使い方について説明します。Where-Objectコマンドを使用すれば、フィルタリングができます。コマンドとともに、使い方を紹介します。
PowerShellでのWhere-Objectコマンドの使い方に興味のある方はぜひご覧ください。
比較演算子
Where-Objectの比較演算子の使い方を紹介します。「-eq」・「-ne」で一致か否か比較できます。
実際のコマンドを見てみましょう。
1
2
3
4
5
6
7
8
|
PS C:\> 1..5 | Where-Object {$_ -eq 1}
1
PS C:\> 1..5 | Where-Object {$_ -ne 1}
2
3
4
5
PS C:\>
|
「lt」・「gt」・「le」・「ge」で大小の比較ができます。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
PS C:\> 1..5 | Where-Object {$_ -lt 3}
1
2
PS C:\> 1..5 | Where-Object {$_ -gt 3}
4
5
PS C:\> 1..5 | Where-Object {$_ -le 3}
1
2
3
PS C:\> 1..5 | Where-Object {$_ -ge 3}
3
4
5
PS C:\>
|
比較演算子を複数連結することもできます。and条件やor条件で連結できます。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
PS C:\> 1..5 | Where-Object {($_ -lt 5) -and ($_ -gt 1)}
2
3
4
PS C:\> 1..5 | Where-Object {($_ -eq 2) -or ($_ -eq 4)}
2
4
PS C:\>
PS C:\> 1..5 | Where-Object {!(($_ -eq 2) -or ($_ -eq 4))}
1
3
5
PS C:\>
|
「contains」で含まれるか否かを判定できます。
1
2
3
4
5
6
7
8
|
PS C:\> 1..5 | Where-Object {$_ -contains 1}
1
PS C:\> 1..5 | Where-Object {$_ -notcontains 1}
2
3
4
5
PS C:\>
|
このように、PowerShellのWhere-Objectでは、比較演算子を使ってフィルタできます。
ワイルドカード比較(like)
PowerShellのWhere-Objectコマンドでは、「like」を使ってワイルドカード比較ができます。
実際のコマンドを見てみましょう。
1
2
3
4
5
6
|
PS C:\> "apple","banana","cherry" | Where-Object {$_ -like "*a*"}
apple
banana
PS C:\> "apple","banana","cherry" | Where-Object {$_ -notlike "*a*"}
cherry
PS C:\>
|
このように、PowerShellのWhere-Objectコマンドでは、「like」を使ってワイルドカード比較ができます。
正規表現比較(match)
PowerShellのWhere-Objectコマンドでは、「match」を使って正規表現比較ができます。
実際のコマンドを見てみましょう。
1
2
3
4
5
6
|
PS C:\> "apple","banana","cherry" | Where-Object {$_ -match "^a.*"}
apple
PS C:\> "apple","banana","cherry" | Where-Object {$_ -notmatch "^a.*"}
banana
cherry
PS C:\>
|
このように、PowerShellのWhere-Objectコマンドでは、「match」を使って正規表現比較ができます。
オブジェクトプロパティのフィルタ
PowerShellでは、オブジェクトプロパティに対してWhere-Objectコマンドを使用できます。ここでは、Get-Commandコマンドをフィルタリングする例を紹介します。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
PS C:\> # Get-Commandの結果先頭10行を表示(すべて表示すると長すぎるので)
PS C:\> Get-Command | Select-Object -First 10
CommandType Name Version Source
----------- ---- ------- ------
Alias Add-AppPackage 2.0.1.0 Appx
Alias Add-AppPackageVolume 2.0.1.0 Appx
Alias Add-AppProvisionedPackage 3.0 Dism
Alias Add-ProvisionedAppPackage 3.0 Dism
Alias Add-ProvisionedAppxPackage 3.0 Dism
Alias Add-ProvisioningPackage 3.0 Provisioning
Alias Add-TrustedProvisioningCertificate 3.0 Provisioning
Alias Apply-WindowsUnattend 3.0 Dism
Alias Disable-PhysicalDiskIndication 2.0.0.0 Storage
Alias Disable-StorageDiagnosticLog 2.0.0.0 Storage
PS C:\>
|
それでは、Sourceプロパティでフィルタをかけてみましょう。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
PS C:\> Get-Command | Where-Object {$_.Source -eq 'Appx'}
CommandType Name Version Source
----------- ---- ------- ------
Alias Add-AppPackage 2.0.1.0 Appx
Alias Add-AppPackageVolume 2.0.1.0 Appx
Alias Dismount-AppPackageVolume 2.0.1.0 Appx
Alias Get-AppPackage 2.0.1.0 Appx
Alias Get-AppPackageDefaultVolume 2.0.1.0 Appx
Alias Get-AppPackageLastError 2.0.1.0 Appx
Alias Get-AppPackageLog 2.0.1.0 Appx
Alias Get-AppPackageManifest 2.0.1.0 Appx
Alias Get-AppPackageVolume 2.0.1.0 Appx
Alias Mount-AppPackageVolume 2.0.1.0 Appx
Alias Move-AppPackage 2.0.1.0 Appx
Alias Remove-AppPackage 2.0.1.0 Appx
Alias Remove-AppPackageVolume 2.0.1.0 Appx
Alias Set-AppPackageDefaultVolume 2.0.1.0 Appx
Function Get-AppxLastError 2.0.1.0 Appx
Function Get-AppxLog 2.0.1.0 Appx
Cmdlet Add-AppxPackage 2.0.1.0 Appx
Cmdlet Add-AppxVolume 2.0.1.0 Appx
Cmdlet Dismount-AppxVolume 2.0.1.0 Appx
Cmdlet Get-AppxDefaultVolume 2.0.1.0 Appx
Cmdlet Get-AppxPackage 2.0.1.0 Appx
Cmdlet Get-AppxPackageManifest 2.0.1.0 Appx
Cmdlet Get-AppxVolume 2.0.1.0 Appx
Cmdlet Invoke-CommandInDesktopPackage 2.0.1.0 Appx
Cmdlet Mount-AppxVolume 2.0.1.0 Appx
Cmdlet Move-AppxPackage 2.0.1.0 Appx
Cmdlet Remove-AppxPackage 2.0.1.0 Appx
Cmdlet Remove-AppxVolume 2.0.1.0 Appx
Cmdlet Set-AppxDefaultVolume 2.0.1.0 Appx
PS C:\>
|
SourceがAppxの一覧が取得できました。
複数条件でフィルタすることもできます。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
PS C:\> Get-Command | Where-Object {($_.Source -eq 'Appx') -and ($_.Name -like 'Get*')}
CommandType Name Version Source
----------- ---- ------- ------
Alias Get-AppPackage 2.0.1.0 Appx
Alias Get-AppPackageDefaultVolume 2.0.1.0 Appx
Alias Get-AppPackageLastError 2.0.1.0 Appx
Alias Get-AppPackageLog 2.0.1.0 Appx
Alias Get-AppPackageManifest 2.0.1.0 Appx
Alias Get-AppPackageVolume 2.0.1.0 Appx
Function Get-AppxLastError 2.0.1.0 Appx
Function Get-AppxLog 2.0.1.0 Appx
Cmdlet Get-AppxDefaultVolume 2.0.1.0 Appx
Cmdlet Get-AppxPackage 2.0.1.0 Appx
Cmdlet Get-AppxPackageManifest 2.0.1.0 Appx
Cmdlet Get-AppxVolume 2.0.1.0 Appx
PS C:\>
|
フィルタされた結果数をカウントすることもできます。
1
2
|
PS C:\> (Get-Command | Where-Object {($_.Source -eq 'Appx') -and ($_.Name -like 'Get*')}).Length
12
|
このように、PowerShellではオブジェクトプロパティに対してWhere-Objectコマンドを使用できます。
まとめ
いかがでしたでしょうか。PowerShellでのWhere-Objectコマンドの使い方について紹介しました。
Where-Objectコマンドを使うことで、自分の好きなようにフィルタリングができます。
ぜひご自身でPowerShellのコマンドを書いて、理解を深めてください。
インフラエンジニア専門の転職サイト「FEnetインフラ」
FEnetインフラはサービス開始から10年以上『エンジニアの生涯価値の向上』をミッションに掲げ、多くのエンジニアの就業を支援してきました。
転職をお考えの方は気軽にご登録・ご相談ください。