gpt4 book ai didi

java - 使用正则表达式去除所有不情愿的花括号

转载 作者:行者123 更新时间:2023-11-30 09:46:05 25 4
gpt4 key购买 nike

注意:这是一道仅限 Java 的问题(即没有 Javascript、sed、Perl 等)

我需要过滤掉一长串文本中所有“不情愿”的大括号 ({})。

(我所说的“不情愿”是指在 reluctant quantifier 中)。

我已经能够想出以下正则表达式,它可以正确找到并列出所有此类事件:

    Pattern pattern = Pattern.compile("(\\{)(.*?)(\\})", Pattern.DOTALL);  
Matcher matcher = pattern.matcher(originalString);
while (matcher.find()) {
Log.d("WITHIN_BRACES", matcher.group(2));
}

我现在的问题是如何用 对应的 matcher.group(2 )

凭直觉我试过:

while (matcher.find()) {
String noBraces = matcher.replaceAll(matcher.group(2));
}

但是这将所有找到的 matcher.group(0) 替换为只有 first matcher.group(2),这当然是不是我想要的。

Java的正则表达式中是否有表达式或方法来执行我需要的这个“对应的replaceAll”?

回答:感谢下面的提示,我已经能够想出 2 个解决方法来解决问题:

if (matcher.find()) {
String noBraces = matcher.replaceAll("$2");
}
  1. 修复 #1:使用 "$2" 代替 matcher.group(2)
  2. 修复 #2:使用 if 而不是 while

现在就像一个魅力。

最佳答案

您可以使用特殊的反向引用语法:

String noBraces = matcher.replaceAll("$2");

关于java - 使用正则表达式去除所有不情愿的花括号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7308634/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com