我需要在一个字符串中执行多个replaceAll
命令,我想知道是否存在一种干净的方法。当前是这样的:
newString = oldString.replaceAll("α","a").replaceAll("β","b").replace("c","σ") /* This goes on for over 60 replacements*/;
答案 0 :(得分:1)
您可以执行以下操作。地图将包含映射,您所需要做的就是遍历映射并调用replace
。
public static void main(String[] args) {
// your input
String old = "something";
// the mappings
Map<Character, Character> mappings = new HashMap<>();
mappings.put('α','a');
// loop through the mappings and perform the action
for (Map.Entry<Character, Character> entry : mappings.entrySet()) {
old = old.replace(entry.getKey(), entry.getValue());
}
}
答案 1 :(得分:1)
如果您只想用单个Character
或另一个Character
替换单个String
,则我已经实施了专门的解决方案:
private static Map<Character, Character> REPLACEMENTS = new HashMap<>();
static {
REPLACEMENTS.put('α','a');
REPLACEMENTS.put('β','b');
}
public static String replaceChars(String input) {
StringBuilder sb = new StringBuilder(input.length());
for(int i = 0;i<input.length();++i) {
char currentChar = input.charAt(i);
sb.append(REPLACEMENTS.getOrDefault(currentChar, currentChar));
}
return sb.toString();
}
此实现避免了过多的字符串复制/复杂的正则表达式,因此与使用replace
或replaceAll
的实现相比,它应该表现得非常好。您也可以将替换项更改为String
,但是替换整个String
而不是Characters
更为复杂-我更喜欢使用正则表达式。
编辑:
这是上述样式的整个String
的解决方案,但我建议您考虑使用其他解决方案,例如regex的性能特征不如上述Character
的示例好。此外,它更复杂,更容易出错,但通过简单的测试就可以正常运行。不过,它仍然避免使用字符串副本,因此在性能敏感的情况下可能更可取。
private static Map<String, String> REPLACEMENTS = new HashMap<>();
static {
REPLACEMENTS.put("aa","AA");
REPLACEMENTS.put("bb","BB");
}
public static String replace(String input) {
StringBuilder sb = new StringBuilder(input.length());
for (int i = 0; i < input.length(); ++i) {
i += replaceFrom(input, i, sb);
}
return sb.toString();
}
private static int replaceFrom(String input, int startIndex, StringBuilder sb) {
for (Map.Entry<String, String> replacement : REPLACEMENTS.entrySet()) {
String toMatch = replacement.getKey();
if (input.startsWith(toMatch, startIndex)) {
sb.append(replacement.getValue());
//we matched the whole word skip all matched characters
//not just the first
return toMatch.length() - 1;
}
}
sb.append(input.charAt(startIndex));
return 0;
}