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

Java正则表达式:让它找到最长的匹配?

宿鹏程
2023-03-14

我有一个这样的正则表达式(仅供举例说明):

(?<number>[0-9]+)|(?<date>[0-9]+\-[0-9]+\-[0-9]+)

应用于2009年11月10日Matcher::lookingAt产生2009年。我可以在API或正则表达式中传递一个标志来告诉引擎考虑最长的匹配吗?

我知道,在这个特殊的情况下,我可以简单地对这两个语句重新排序,但我正在以编程方式从几个正则表达式中组装正则表达式,我希望它们的顺序不影响什么匹配和什么不匹配。

我正在使用Java 8。

共有1个答案

孙夕
2023-03-14

唯一(通用)的方法是对组重新排序。在这种情况下,你知道最长的比赛将是第二组,所以它需要放在第一位。这是因为正则表达式是从左到右解析的,以找到匹配项。

或者,对于这种情况,您可以用边界匹配标记行的开始和结束来包装正则表达式:

^(([0-9]+)|([0-9]+\-[0-9]+\-[0-9]+))$

只有当输入匹配整行时,才会找到最长的匹配。

 类似资料:
  • 问题内容: 我的代码: 输出: 我知道的 : “一个?” 代表零个或一次出现的字符“ a”。 Java API说: matcher.start()返回上一个匹配项的起始索引。 matcher.end()返回匹配的最后一个字符后的偏移量。 matcher.group()返回与上一个匹配项匹配的输入子序列。对于具有输入序列s的匹配器m,表达式m.group()和s.substring(m.start(

  • 问题内容: 当字符串以数字开头时,我需要匹配,然后是一个点,然后是一个空格和1个或多个大写字符。匹配必须发生在字符串的开头。我有以下字符串。 我尝试过的正则表达式是: 它不匹配。一个有效的正则表达式将对这个问题有什么作用? 问题答案: (对不起,我先前的错误。大脑现在坚定地投入了。嗯,也许。) 这有效: 分解: =字符串开头 =一个或多个数字 (之所以转义,是因为它在字符串中,因此) =文字(或者

  • 问题内容: 我从以下格式的文件中获取输入: 现在,我想在我的Java代码中读取int1,int2,int3和int4。我该如何在Java中使用正则表达式匹配。谢谢。 问题答案: 为了避免空值:

  • 有没有人试图描述与正则表达式匹配的正则表达式? 由于重复的关键字,这个主题几乎不可能在网上找到。 它可能在实际应用程序中不可用,因为支持正则表达式的语言通常具有解析它们的方法,我们可以将其用于验证,以及一种在代码中分隔正则表达式的方法,可用于搜索目的。 但是我仍然想知道匹配所有正则表达式的正则表达式是什么样子的。应该可以写一个。