MatchCollectionクラスは、名前の通り複数のMatchを格納するためのコレクションクラスです。 Regex.Matchesメソッドは戻り値の型がMatchCollectionとなっていて、正規表現にマッチした箇所すべてに対応するMatchが格納された状態で返されます。
Regex.Matchesメソッドから返されるMatchCollectionには、正規表現にマッチした箇所のみを表すMatchが含まれるため、このMatchCollectionからはすべてSuccessプロパティがTrue
のMatchが列挙されることになります。 そのため、個別にSuccessプロパティをチェックする必要はありません。
using System;
using System.Text.RegularExpressions;
class Sample {
static void Main()
{
var text = "The quick brown fox jumps over the lazy dog";
var pattern = @"\w{4,}"; // 4文字以上の単語
// マッチする個所すべてを列挙
// (MatchCollectionは非ジェネリックで型指定されていないIEnumeratorを返すため、varによる暗黙的な型指定はできない)
foreach (Match m in Regex.Matches(text, pattern)) {
Console.WriteLine(m.Value);
}
}
}
quick brown jumps over lazy
MatchCollectionは当初、非ジェネリックなIEnumerableのみを実装した型指定されていないコレクションとして登場し、その後.NET Standard 2.1/.NET Core 2.0にてIEnumerable<Match>/ICollection<Match>/IList<Match>を実装するようになり、型指定されたコレクションとして扱うことができるようになっています。
一方、IEnumerable<Match>の実装以降でも、MatchCollection.GetEnumeratorメソッドは(おそらく)互換性のため型指定されていないIEnumeratorを返す実装のままとなっています。 このため、MatchCollectionをforeachで列挙する場合、var
による暗黙的な型指定を行うとobject
として列挙されます。
代替手法やMatchCollectionのジェネリックインターフェイスについてより詳しくは§.MatchCollection・GroupCollection・CaptureCollectionとジェネリックコレクションインターフェイスを参照してください。
MatchCollectionは当初IEnumerableのみを実装した型指定されていないコレクションとして登場し、その後.NET Standard 2.1/.NET Core 2.0にてIEnumerable<Match>/ICollection<Match>/IList<Match>を実装するようになり、型指定されたコレクションとして扱うことができるようになっています。
一方、IEnumerable<Match>の実装以降でも、MatchCollection.GetEnumeratorメソッドは(おそらく)互換性のため型指定されていないIEnumeratorを返す実装のままとなっています。 このため、MatchCollectionをforeachで列挙する場合、var
による暗黙的な型指定を行うとobject
として列挙されます。