gpt4 book ai didi

Java - 正则表达式全部替换不会替换匹配的文本

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

尝试从字符串中删除大量 unicode,但在 java 中的正则表达式出现问题。

示例文本:

\u2605 StatTrak\u2122 Shadow Daggers

期望结果示例:

StatTrak Shadow Daggers

我当前的正则表达式代码不起作用:

list.replaceAll("\\\\u[0-9]+","");

代码将执行,但文本不会被替换。从其他解决方案来看,人们似乎只使用两个“\\”,但任何小于 4 的内容都会引发典型错误:

Exception in thread "main" java.util.regex.PatternSyntaxException: Illegal Unicode escape sequence near index 2 \u[0-9]+

我已经在在线测试环境中尝试了当前的正则表达式解决方案,例如 RegexPlanetFreeFormatter并且都给出了正确的结果。

如有任何帮助,我们将不胜感激。

最佳答案

假设您想将“特殊字符串”替换为空字符串。正如我所见, \u2605\u2122POSIX 字符类。这就是为什么我们可以尝试将这些可打印字符替换为“”。然后,结果就和你期望的一样了。

示例为:

list = list.replaceAll("\\P{Print}", "");

希望这有帮助。

关于Java - 正则表达式全部替换不会替换匹配的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45850767/

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