我有一个正则表达式,它拉取名称值对
([^=;]*)=([^;]*)
"Data Source=server;Initial Database=myDB;foo=bar;"
这很好用,我可以使用下面的命令得到第一个结果
m.Groups[0] // "Data Source=server"
m.Groups[1] // "Data Source"
m.Groups[2] // "Server"
我怎么才能找到第二组和第三组比赛?我的术语可能是错误的,我也希望能得到帮助。
谢谢!
发布于 2009-07-15 23:51:06
Regex r = new Regex("([^=;]*)=([^;]*)");
MatchCollection mc = r.Matches("Data Source=server;Initial Database=myDB;foo=bar;");
foreach (Match m in mc)
{
Console.WriteLine(m.Groups[0]);
Console.WriteLine(m.Groups[1]);
Console.WriteLine(m.Groups[2]);
}
发布于 2009-07-16 00:07:49
正如eschneider所指出的,在这种情况下使用正则表达式有点过头了。定时器
string thestring ="Data Source=server;Initial Database=myDB;foo=bar;";
var keyVals = from kv in thestring.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries)
select new KeyValuePair<string,string>(kv.Split('=')[0],kv.Split('=')[1]);
foreach (var keyVal in keyVals) {
Console.WriteLine(keyVal.Key);
Console.WriteLine(keyVal.Value);
}
发布于 2009-07-15 23:52:01
Match.NextMatch()方法可能就是您正在寻找的方法:
string text = "Data Source=server;Initial Database=myDB;foo=bar;";
Regex re = new Regex("([^=;]*)=([^;]*)");
var m = re.Match(text);
while (m.Success)
{
Console.Out.WriteLine("variable: {0} equals {1}", m.Groups[1], m.Groups[2]);
m = m.NextMatch();
}
有关更完整的代码示例,请参阅此MSDN page
https://stackoverflow.com/questions/1134678
复制相似问题