当前位置: 首页 > 知识库问答 >
问题:

中两个子字符串之间的非贪婪正则表达式匹配。净[重复]

施永贞
2023-03-14

示例文本:

heading1
foo=bar
baz=qux

heading2
spam=ham

heading3
this=that

我希望文本从标题 1标题 2(不包括)。

所以我尝试了一个从“heading1”到“\n\n”的非贪婪匹配,但它仍然是贪婪和过度匹配的:

var result = Regex.Match(text, "heading1\n(.*)\n{2}?", RegexOptions.Singleline)
  .Groups[1]
  .Value;

(我已经有了一个解决方案,通过在"head ing1""head ing2"之间搜索,但我更喜欢使用上述方法作为非贪婪匹配的学习练习。)

更新:
我的问题更简单,有源文本,专门针对C#。更容易理解问题。链接的问题在技术上是相关的,但更难应用于这种情况。

共有2个答案

仲璞瑜
2023-03-14

你在错误的地方应用了非贪婪,因为\n{2}是一个固定的量词,根本不需要贪婪。

相反,您应该编写< code >。*非贪婪,使用< code >。*?以避免匹配双换行符:

heading1\n(.*?)\n{2}
弘志勇
2023-03-14

您可以使用此正则表达式来匹配:

^heading1\n((?:.+\n)*)

或者,如果标题 2 必须在比赛后出现,那么:

^heading1\n((?:.+\n)*)(?=\n+heading2\n)

正则表达式演示

正则表达式详细信息:

  • ^:线的起点
  • < li> heading1\n:匹配< code>heading1后跟< code>\n < li> (:开始捕获组#1 < ul > < li> (?:.\n)*:

代码:

string pattern = @"^heading1\n((?:.+\n)*)";
RegexOptions options = RegexOptions.Multiline;
        
foreach (Match m in Regex.Matches(input, pattern, options)) {
   Console.WriteLine("'{0}' found at index {1}.", m.Value, m.Index);
}
  • (?=\n 标题 2\n):积极的展望,断言我们有 1 个换行符,然后是标题 2 和前面的换行符
 类似资料:
  • 考虑字符串。如何以非贪婪的方式(在awk中)匹配和之间的内容? 我尝试了以下方法: 没有输出。我相信不匹配的原因是“”和之间的字符数为奇数。如果我用替换 ,正则表达式似乎可以工作。

  • 问题内容: 我如何制作像这样的python正则表达式,使得在给定的情况下,python匹配而不是? 我知道我可以使用代替,但是我正在寻找一种更通用的解决方案,使我的regex更加整洁。有什么办法告诉python“嘿,尽快匹配它”? 问题答案: 您寻找功能强大的吗? http://docs.python.org/3/howto/regex.html#greedy-versus-non-greedy

  • 问题内容: 我有下一个代码: 并具有下一个输出: 但我认为它必须是: 有人请解释为什么。 问题答案: 由于您的模式是非贪婪的,因此它们在仍由匹配项组成的情况下,匹配的文本越少越好。 去除 ?在第二组中,您会得到 单词 word word big small

  • 我需要关于非贪婪选项的正则表达式匹配的帮助。 匹配模式为: 要匹配的文本是: 我在上测试http://regexpal.com 此表达式匹配 ,没有成功。

  • 本文向大家介绍php正则表达式中贪婪与非贪婪介绍,包括了php正则表达式中贪婪与非贪婪介绍的使用技巧和注意事项,需要的朋友参考一下 一、贪婪与非贪婪 什么叫贪婪,比如说要从字符串中<td>面包一</td><td>面包二</td>吃面包,本来你只可以吃面包一,可是你贪心,于是就把第一个<td>到最后一个</td>里面的两个面包取出来了,你想多吃点,非贪婪也就是你不贪吃了,就只吃面包一。 我们来看看正

  • 本文向大家介绍Python正则表达式教程之三:贪婪/非贪婪特性,包括了Python正则表达式教程之三:贪婪/非贪婪特性的使用技巧和注意事项,需要的朋友参考一下 之前已经简单介绍了Python正则表达式的基础与捕获,那么在这一篇文章里,我将总结一下正则表达式的贪婪/非贪婪特性。  贪婪 默认情况下,正则表达式将进行贪婪匹配。所谓“贪婪”,其实就是在多种长度的匹配字符串中,选择较长的那一个。例如,如下