繁体   English   中英

Java正则表达式捕获重复的组

[英]Java regular expression to capture repetive groups

我无法通过正则表达式捕获第2组中的所有数据,包括所有字符,数字,空格和特殊字符

尝试过正则表达式

 final String regex = "^:(.*?)//(.*[\\s\\S]?)";
    String line1 = ":Humpty Dumpty sat on a wall";
    String line2 = "//Humpty Dumpty had a great fall";
    String rhyme = line1 +  line2+"\n"+ "ssdsds"+"\n";
    final String value = rhyme.replaceAll(regex , "$2");
 final boolean formatIdentified =   rhyme.matches(formatRegex);
System.out.println(formatIdentified);//returns false

我期望的价值

"Humpty Dumpty had a great fall
 ssdsds
"

更正后的正则表达式应使用格式:abc//xxxx ,输出应为xxxx

String.replaceAllString.matches完全有可能以不同的方式处理多行字符串的终止符,即换行符与字符串的结尾,这就是为什么value可以打印预期结果但matches结果显示false的原因。

我将更加明确,直接使用PatternMatcher而不是通过String进行代理:

        String rhyme =
                ":Humpty Dumpty sat on a wall\n" +
                "//Humpty Dumpty had a great fall\n" +
                "ssdsds\n";

        Pattern pattern = Pattern.compile("^:(.*?)//(.*[\\s\\S]?)", Pattern.DOTALL);
        Matcher matcher = pattern.matcher(rhyme);
        if (matcher.find()) {
            System.out.println(matcher.group(2));
        } else {
            System.out.println("[Pattern not found]");
        }

这将输出:

   Humpty Dumpty had a great fall
   ssdsds

如果期望只匹配一个新行结尾,则只需将标志更改为Pattern.MULTILINE。

   Pattern pattern = Pattern.compile("^:(.*?)//(.*[\\s\\S]?)", Pattern.MULTILINE);

将输出:

   Humpty Dumpty had a great fall

这将提供您想要的输出。

      // ignore everything up to // and then include // and all following
      // in capture group 1.
      final String regex = ".*(//.*)";
      String line1 = ":Humpty Dumpty sat on a wall";
      String line2 = "//Humpty Dumpty had a great fall";
      String rhyme = line1 + line2 + "\n" + "ssdsds" + "\n";
      final String value = rhyme.replaceAll(regex, "$1");
      System.out.println(value);
          // or the follwing if you want the double quotes.
      System.out.println("\"" + value + "\"");

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM