正则表达式一不用就忘掉了,之前写的都是JS的正则,这里记录一下c#的正则怕以后忘记,这里用的是获取双引号用的内容
string str = "a: 3:{ i: 1; s: 51:\"images /2/2017/06/c4ZElEp2elObaCme7XXevlcZacZlyL.jpg\"; i: 2; s: 51:\"images/2/2017/06/Ur2T7GDzcGWZwgYw2Trsbd38br352d.jpg\"; i: 3; s: 51:\"images/2/2017/06/ET94c4qn1qz4141o41q4idI4ZC1Mwt.jpg\"; }";
//初始化字符串
//定义正则表达式规则 (非贪婪模式)
Regex reg = new Regex("(\").+?(\")");
//返回一个结果集
MatchCollection result = reg.Matches(str);
//遍历每个结果
foreach (Match m in result)
{
this.listBox1.Items.Add(m.ToString());
}
以上是非贪婪模式。。
下面的是贪婪模式
string str = "a: 3:{ i: 1; s: 51:\"images /2/2017/06/c4ZElEp2elObaCme7XXevlcZacZlyL.jpg\"; i: 2; s: 51:\"images/2/2017/06/Ur2T7GDzcGWZwgYw2Trsbd38br352d.jpg\"; i: 3; s: 51:\"images/2/2017/06/ET94c4qn1qz4141o41q4idI4ZC1Mwt.jpg\"; }";
//初始化字符串
//定义正则表达式规则
Regex reg = new Regex("(\").+(\")");
//返回一个结果集
MatchCollection result = reg.Matches(str);
//遍历每个结果
foreach (Match m in result)
{
this.listBox1.Items.Add(m.ToString());
}
另外有的时候,会发现,获取到的m.Tostring()里面会包含了 双引号 如果需要去除双引号 需要用到分组:
那么代码就是:
string str = "a: 3:{ i: 1; s: 51:\"images /2/2017/06/c4ZElEp2elObaCme7XXevlcZacZlyL.jpg\"; i: 2; s: 51:\"images/2/2017/06/Ur2T7GDzcGWZwgYw2Trsbd38br352d.jpg\"; i: 3; s: 51:\"images/2/2017/06/ET94c4qn1qz4141o41q4idI4ZC1Mwt.jpg\"; }";
//初始化字符串
//定义正则表达式规则
Regex reg = new Regex("(\")(?<path>.+?)(\")");
//返回一个结果集
MatchCollection result = reg.Matches(str);
//遍历每个结果
foreach (Match m in result)
{
this.listBox1.Items.Add(m.Groups["path"].Value);
}
那么就会得到 想要的结果集合了。
好了,就到这里,随着知识量越来越广,很多东西也怕以后忘记,能快速找回,写个博客记录下