微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 在.Net正则表达式中有效地组合MatchCollections

在简化的例子中,有2个正则表达式,一个区分大小写,另一个不是.这个想法将是有效地创建一个IEnumerable集合(参见下面的“组合”),结合结果.
string test = "abcABC";
string regex = "(?<grpa>a)|(?<grpb>b)|(?<grpc>c)]";
Regex regNoCase = new Regex(regex,RegexOptions.IgnoreCase);
Regex regCase = new Regex(regex);

MatchCollection matchNoCase = regNoCase.Matches(test);
MatchCollection matchCase = regCase.Matches(test);

//Combine matchNoCase and matchCase into an IEnumerable
IEnumerable<Match> combined= null;
foreach (Match match in combined)
{
    //Use the Index and (successful) Groups properties 
    //of the match in another operation

}

在实践中,MatchCollections可能包含数千个结果,并可以使用长时间动态创建的REGEXes来运行,所以我想避免将结果复制到数组等.我还在学习LINQ,并且对如何去做模糊将这些或性能与现有的缓慢过程结合起来.

解决方法

这里有三个步骤:

>将MatchCollection转换为IEnumerable< Match>
连接序列
>根据Match.Success属性是否为true进行过滤

码:

IEnumerable<Match> combined = matchNoCase.OfType<Match>().Concat(matchCase.OfType<Match>()).Where(m => m.Success);

这样做会创建一个新的枚举器,它只在执行下一个结果时执行每个步骤,所以最终只能通过每个集合枚举一次.例如,Concat()将在第一次用完后才开始执行第二个枚举器.

原文地址:https://www.jb51.cc/csharp/92266.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐