以下のようなテキストの文字列がある場合、改行を超えていても、c# のコレクション内のブラケットの内容を収集するにはどうすればよいですか?
例えば...
string s = "test [4df] test [5yu] test [6nf]";
私に与えるべき..
コレクション[0] = 4df
コレクション[1] = 5ユウ
コレクション[2] = 6nf
これは、正規表現と少しの Linq を使用して行うことができます。
string s = "test [4df] test [5y" + Environment.NewLine + "u] test [6nf]";
ICollection<string> matches =
Regex.Matches(s.Replace(Environment.NewLine, ""), @"\[([^]]*)\]")
.Cast<Match>()
.Select(x => x.Groups[1].Value)
.ToList();
foreach (string match in matches)
Console.WriteLine(match);
出力:
4df
5yu
6nf
正規表現の意味は次のとおりです。
\[ : Match a literal [
( : Start a new group, match.Groups[1]
[^]] : Match any character except ]
* : 0 or more of the above
) : Close the group
\] : Literal ]
Regex regex = new Regex(@"\[[^\]]+\]", RegexOptions.Multiline);
重要なのは、正規表現で使用される特殊文字を正しくエスケープすることです。たとえば、[次の方法で文字を一致させることができます。@"\["
Regex rx = new Regex(@"\[.+?\]");
var collection = rx.Matches(s);
角かっこを削除する必要があります。重要な部分は遅延演算子です。