假设输入字符串:
A-B-C-B-Z
我正在尝试替换 A
和 Z
之间的任何 B
。
以下正则表达式仅匹配最后一次出现的 B
:
(.*A.*)B(.*Z.*)
...用 $1-$2
替换 (Pattern.replaceAll()
) 时,结果为
A-B-C---Z
预期结果是
A---C---Z
相反。
感谢您的帮助!
最佳答案
在 Java 中,您可以使用如下所示的环视:
String str = "F-B-P-B-A-B-C-B-Z-D-B-A-B-C-B-Z-C";
String repl = str.replaceAll("(?<=A.{0,999})B(?=((?!A|Z).)*Z)", "-");
//=> F-B-P-B-A---C---Z-D-B-A---C---Z-C
根据您的评论,您可以使用此正则表达式:
String repl = str.replaceAll(
"(?<=<!\\[CDATA\\[.{0,999})&(?=((?!<!\\[CDATA\\[|\\]\\]>).)*\\]\\]>)", "-");
需要注意的是,这是假设您的输入长度最多为 999。
关于Java 正则表达式 : replace any B between A and Z,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28791957/