regex - 一个关于查找数字字符串的Java正则表达式

标签 regex

我正在网上学习 Java 正则表达式教程,并对一个小程序感到困惑。

  // String to be scanned to find the pattern.
  String line = "This order was places for QT3000! OK?";
  String pattern = "(.*)(\\d+)(.*)";

  // Create a Pattern object
  Pattern r = Pattern.compile(pattern);

  // Now create matcher object.
  Matcher m = r.matcher(line);
  if (m.find( )) {
     System.out.println("Found value: " + m.group(0) );
     System.out.println("Found value: " + m.group(1) );
     System.out.println("Found value: " + m.group(2) );
  } 

打印出来的结果是:

Found value: This order was places for QT3000! OK?

Found value: This order was places for QT300

Found value: 0

我不知道为什么 group(1) 的值是上面的值?为什么它在“QT3000”的最后一个零之前停止?

非常感谢!

最佳答案

第一组(.*)(这是索引1 - 索引0是整个正则表达式)是贪婪匹配。它尽可能多地捕捉,同时让整体表达仍然匹配。因此,它最多可以占用字符串中的第二个 0,仅留下 0 来匹配 (\\d+)。如果您想要不同的行为,那么您应该阅读贪婪和非贪婪匹配,或者找到更合适的模式。

关于regex - 一个关于查找数字字符串的Java正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11434913/

相关文章:

c - 需要图路径抽象算法

regex - 调试 perl 分配

regex - R - 计算行数 w/@ 符号

java - 获取与正则表达式匹配的每个字符串的数组

regex - 在 R 中的特定字符串后检索数字

.net - 为什么编译的正则表达式性能比解释的正则表达式慢?

Python:使用 re.match 检查字符串

java - Clojure 的正则表达式解析/编译有多智能?

java - 如何正确使用此 Java 正则表达式的否定先行?

python - 用一个空格替换任意数量的空格