目次
PowerShellでのMatchesの使い方を解説します!
今回は、PowerShellでのMatchesの使い方について説明します。
PowerShellでは、正規表現でMatchesを利用します。
正規表現に一致した文字列が格納されます。
ここでは、以下について紹介します。
・基本的な使い方
・配列に対する正規表現
・複数マッチ
・末尾マッチ
・groups
・Select-StringのMatches
・最長マッチと最短マッチ
PowerShellでのMatchesの使い方に興味のある方はぜひご覧ください。
基本的な使い方
PowerShellでのMatchesの基本的な使用方法を紹介します。
実際のコマンドを見てみましょう。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
PS C:\> # マッチするか判定
PS C:\> "abc123def456" -match "[a-z]+"
True
PS C:\> # マッチした内容を表示
PS C:\> $Matches
Name Value
---- -----
0 abc
PS C:\> "abc123def456" -match "^[0-9]"
False
PS C:\> "abc123def456" -match "[0-9]$"
True
PS C:\> $Matches
Name Value
---- -----
0 6
PS C:\>
|
マッチした内容は$Matchesに格納されています。
配列に対する正規表現
PowerShellでは、配列に対して正規表現を使用できます。
実際のコマンドを見てみましょう。
1
2
3
4
5
6
7
8
9
|
PS C:\> "123","abc","456","def","78g" -match "\d"
123
456
78g
PS C:\> "123","abc","456","def","78g" -match "[a-z]"
abc
def
78g
PS C:\>
|
正規表現にマッチする配列要素が抽出されていることが分かります。
複数マッチ
PowerShellでの複数マッチする場合の書き方を紹介します。
実際のコマンドを見てみましょう。
1
2
3
4
5
6
7
8
9
10
|
PS C:\> [RegEx]::Matches("abc123def456", "[0-9]+") | % {$_.Value}
123
456
PS C:\> [RegEx]::Matches("abc123def456", "\d+") | % {$_.Value}
123
456
PS C:\> [RegEx]::Matches("abc123def456", "[a-z]+") | % {$_.Value}
abc
def
PS C:\>
|
マッチした部分が抽出されていることが分かります。
配列にマッチ結果を格納することもできます。
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
|
PS C:\> $matches=[RegEx]::Matches("abc123def456", "[a-z]+")
PS C:\> # マッチした数
PS C:\> $matches.Count
2
PS C:\> $matches
Groups : {0}
Success : True
Name : 0
Captures : {0}
Index : 0
Length : 3
Value : abc
Groups : {0}
Success : True
Name : 0
Captures : {0}
Index : 6
Length : 3
Value : def
PS C:\> # 1つ目にマッチした内容
PS C:\> $matches[0].Value
abc
PS C:\> # 2つ目にマッチした内容
PS C:\> $matches[1].Value
def
PS C:\>
|
末尾マッチ
複数マッチした場合の末尾を取得する方法を紹介します。
Select-ObjectコマンドのLastオプションを使用します。
実際のコマンドを見てみましょう。
1
2
3
4
5
|
PS C:\> [RegEx]::Matches("abc123def456", "[a-z]+") | Select-Object -Last 1 | % {$_.Value}
def
PS C:\> [RegEx]::Matches("abc123def456ghi", "[a-z]+") | Select-Object -Last 1 | % {$_.Value}
ghi
PS C:\>
|
一度変数に格納しても末尾だけ取得できます。
1
2
3
4
|
PS C:\> $matches=[RegEx]::Matches("abc123def456ghi", "[a-z]+")
PS C:\> $matches[$matches.Count-1].Value
ghi
PS C:\>
|
groups
PowerShellでのgroupsの使い方を紹介します。
実際のコマンドを見てみましょう。
要素0がマッチした文字列全体、要素1以降が部分マッチした文字列になります。
1
2
3
4
5
6
7
8
9
10
|
PS C:\> # マッチした文字列全体
PS C:\> [regex]::Match("abcde","(.)(.)").captures.groups[0].value
ab
PS C:\> # 部分マッチした文字列1
PS C:\> [regex]::Match("abcde","(.)(.)").captures.groups[1].value
a
PS C:\> # 部分マッチした文字列2
PS C:\> [regex]::Match("abcde","(.)(.)").captures.groups[2].value
b
PS C:\>
|
Select-StringのMatches
PowerShellでのSelect-StringコマンドでもPatternオプションを使えば正規表現を使えます。
実際のコマンドを見てみましょう。
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
37
38
|
PS C:\> Get-Command | Select-String -Pattern "Wait*" | foreach {$_.Matches}
Groups : {0}
Success : True
Name : 0
Captures : {0}
Index : 0
Length : 4
Value : Wait
Groups : {0}
Success : True
Name : 0
Captures : {0}
Index : 0
Length : 4
Value : Wait
Groups : {0}
Success : True
Name : 0
Captures : {0}
Index : 0
Length : 4
Value : Wait
Groups : {0}
Success : True
Name : 0
Captures : {0}
Index : 0
Length : 4
Value : Wait
PS C:\>
|
最長マッチと最短マッチ
PowerShellでの最長マッチと最短マッチについて紹介します。
最長マッチとは、正規表現が一番長くマッチする文字列で、最短マッチとは、正規表現が一番短くマッチする文字列です。
実際のコマンドを見てみましょう。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
PS C:\> "abc123abc456abc789abc" -match "abc.*abc"
True
PS C:\> $Matches
Name Value
---- -----
0 abc123abc456abc789abc
PS C:\> "abc123abc456abc789abc" -match "abc.*?abc"
True
PS C:\> $Matches
Name Value
---- -----
0 abc123abc
PS C:\>
|
最長マッチには*、最短マッチには*?を使用します。
まとめ
いかがでしたでしょうか。PowerShellでのMatchesの使い方について説明しました。
PowerShellでは、正規表現でMatchesを利用します。
正規表現に一致した文字列が$Matchesに格納されます。
ぜひご自身でコマンドを書いて、理解を深めてください。
インフラエンジニア専門の転職サイト「FEnetインフラ」
FEnetインフラはサービス開始から10年以上『エンジニアの生涯価値の向上』をミッションに掲げ、多くのエンジニアの就業を支援してきました。
転職をお考えの方は気軽にご登録・ご相談ください。