C# の正規表現グループ: 一致結果を理解する
次の C# コード ブロックについて考えてみましょう。
<code class="csharp">var pattern = @"\[(.*?)\]"; var matches = Regex.Matches(user, pattern); if (matches.Count > 0 && matches[0].Groups.Count > 1) ...</code>
Thisコードは正規表現を使用して、ユーザー入力文字列から括弧で囲まれたテキストを抽出します。入力「Josh Smith [jsmith]」の場合、コードは次の結果を正しく返します:
matches.Count == 1 matches[0].Value == "[jsmith]"
ただし、後続の行では疑問が生じます:
matches[0].Groups.Count == 2 matches[0].Groups[0].Value == "[jsmith]" matches[0].Groups[1].Value == "jsmith"
Match Grouping
正規表現では、一致の特定の部分をキャプチャするためにグループが使用されます。デフォルトでは、一致全体がグループ 0 にキャプチャされます。括弧を使用して追加のキャプチャ グループを定義できます。
提供されたコードでは、正規表現は (.*?) で示される単一のキャプチャ グループを定義します。このグループは、角括弧内のテキスト (この場合は jsmith) をキャプチャします。したがって、
Nested Groups
より複雑な正規表現では、ネストされたグループを持つことができます。このような場合、各グループには独自のキャプチャのセットが含まれます。ただし、指定されたコードでは、グループ化のレベルが 1 つしかないため、
その他の考慮事項
以上がC# の正規表現グループは一致する部分文字列をどのようにキャプチャしてアクセスするのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。