C# 从c中的正则表达式获取结果

C# 从c中的正则表达式获取结果,c#,regex,C#,Regex,我有一个正则表达式,它提取名称-值对 ([^=;]*)=([^;]*) "Data Source=server;Initial Database=myDB;foo=bar;" 这很好,我可以使用 m.Groups[0] // "Data Source=server" m.Groups[1] // "Data Source" m.Groups[2] // "Server" 我怎样才能进入第二组和第三组比赛?我的术语可能是错误的,我也希望得到帮助 谢谢 方法可能就是您想要的: Regex r

我有一个正则表达式,它提取名称-值对

([^=;]*)=([^;]*)

"Data Source=server;Initial Database=myDB;foo=bar;"
这很好,我可以使用

m.Groups[0] // "Data Source=server"
m.Groups[1] // "Data Source"
m.Groups[2] // "Server"
我怎样才能进入第二组和第三组比赛?我的术语可能是错误的,我也希望得到帮助

谢谢

方法可能就是您想要的:

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]);
}
     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();
     }
有关更完整的代码示例,请参见此

方法可能正是您想要的:

     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();
     }

有关更完整的代码示例,请参见此

,正如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);
}

正如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);
}