gpt4 book ai didi

java - 使用 Java RegEx 全局替换分组匹配

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

我有以下 PERL 一行代码。这个 perl RegEx 只是将给定句子中所有单词的首字母大写。

$val =~ s/\b(.)(.*?)\b/uc($1).$2/eg;

输入:

"united states corp"

输出

"United States Corp"

但是,我需要在JAVA中实现相同的功能。我正在做以下事情。

String INPUT="united states corp"
Pattern p = Pattern.compile("\\b(.)(.*?)\\b");
Matcher m = p.matcher(INPUT);
if (m.find()) {
INPUT = m.replaceAll(m.group(1).toUpperCase() + m.group(2));
}

输入:

"United States Corp".

输出:

"UnitedUnitedUnitedUnitedUnited"

谢谢。

最佳答案

要匹配单词的第一个小写字母(为了不匹配那些已经大写的字母),您可以使用 \b\p{Ll} 正则表达式并使用 Matcher#appendReplacement( ) 操作匹配的方法:

String INPUT="united states corp";
Pattern p = Pattern.compile("\\b\\p{Ll}");
StringBuffer result = new StringBuffer();
Matcher m = p.matcher(INPUT);
while (m.find()) {
m.appendReplacement(result, m.group().toUpperCase());
}
m.appendTail(result);
System.out.println(result.toString()); // => United States Corp

请参阅Java demo .

根据 Java Matcher class docs :

The appendReplacement and appendTail methods can be used in tandem in order to collect the result into an existing string buffer

因此,如果您使用当前的正则表达式 "\\b(.)(.*?)\\b",则需要替换 while (m.find ()) 主体与

m.appendReplacement(result, m.group(1).toUpperCase() + m.group(2));

关于java - 使用 Java RegEx 全局替换分组匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51342824/

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