首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >String.Split VS.Regex.Split?

String.Split VS.Regex.Split?
EN

Stack Overflow用户
提问于 2010-08-30 22:49:54
回答 3查看 23.3K关注 0票数 15

如果我有一个带有基本分隔符的带分隔符的文本文件(例如| ),我使用String还是Regex拆分会有区别吗?

与另一个相比,我会看到性能上的提升吗?

我假设如果你有不想拆分的escaped分隔符(例如\|),你会想要使用Regex.Split

还有没有其他使用Regex.SplitString.Split的原因

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-08-30 22:54:04

Regex.Split功能更强大,但对于具有基本分隔的排列(使用字符串中其他任何地方都不存在的字符),String.Split函数更易于使用。

就性能而言,您必须创建一个测试并对其进行测试。但是,不要预优化,除非你知道这个函数会成为一些基本过程的瓶颈。

票数 14
EN

Stack Overflow用户

发布于 2010-08-30 23:04:13

默认情况下,我会使用String.Split,除非您有一些复杂的需求,可以使用正则表达式来导航。当然,正如其他人所提到的,根据您的需要对其进行配置。也要确保在使用和不使用RegexOptions.Compiled的情况下进行分析,并了解它的工作原理。查看To Compile or Not To CompileHow does RegexOptions.Compiled work?,并搜索有关该主题的其他文章。

String.Split的一个好处是它的StringSplitOptions.RemoveEmptyEntries,它可以在分隔符之间没有数据的情况下删除空结果。相同拆分字符串/字符的正则表达式模式将具有多余的空条目。它是次要的,可以通过一个简单的LINQ查询来处理,以过滤出String.Empty结果。

也就是说,如果需要的话,正则表达式可以非常容易地包含分隔符。这是通过在模式周围添加括号()以使其成为捕获组来实现的。例如:

代码语言:javascript
复制
string input = "a|b|c|d|e|f";
foreach (var s in Regex.Split(input, @"\|"))
    Console.WriteLine(s);

Console.WriteLine("Include delimiter...");
// notice () around pattern
foreach (var s in Regex.Split(input, @"(\|)"))
    Console.WriteLine(s);

你可能会发现这个问题也很有帮助:How do I split a string by strings and include the delimiters using .NET?

票数 4
EN

Stack Overflow用户

发布于 2010-08-30 23:29:37

  1. 对于简单分隔符,您应该使用String.Split,例如逗号分隔的电子邮件地址。
  2. 对于复杂分隔符(使用正则表达式),例如如果将分隔符放在引号中,则不应对其进行分隔,例如A,B=两个标记,A& B“A,B”=一个标记,忽略引号内的逗号
  3. 以包括分隔符,如Ahmad

所建议的那样

哪一个会更快,这是非常主观的。正则表达式的执行速度会更快,但是正则表达式的编译时间和设置时间在实例创建时会更长。但如果一开始就准备好regex对象,重用相同的regex进行拆分会更快。

String.Split不需要任何设置时间,但它是纯粹的顺序搜索操作,对于大文本,它的工作速度会更慢。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3601465

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档