Java字符串替换

时间:2015-05-26 13:18:51

标签: java string str-replace apache-stringutils

假设我有一个字符串"aabbccaa"。现在我想用另一个字符串替换给定字符串中"aa"的出现次数。但它应该是以下列方式。

首次出现的"aa"应由"1"替换,下次出现的"aa"应由"2"替换,依此类推。

因此,字符串的结果变为"1bbcc2"

4 个答案:

答案 0 :(得分:10)

您可以在计数器递增的for循环中使用replaceFirst() ...

for (int i = 1; string.contains("aa"); i++) {
    string = string.replaceFirst("aa", "" + i);
}

答案 1 :(得分:5)

您可以使用Matcher的{​​{3}}方法执行此操作:

Pattern p = Pattern.compile("aa");
Matcher m = p.matcher("aabbccaahhhaahhhaaahahhahaaakty");
StringBuffer sb = new StringBuffer();
// Variable "i" serves as a counter. It gets incremented after each replacement.
int i = 0;
while (m.find()) {
    m.appendReplacement(sb, ""+(i++));
}
m.appendTail(sb);
System.out.println(sb.toString());

这种方法可以避免创建多个字符串对象(appendReplacement)。

答案 2 :(得分:0)

可以使用Java函数,但使用char数组并使用较低级别的逻辑执行它会更快。

String s = "aabbccaa";
String target = "aa";
int i = 1;
String newS;

for (int j = 0; j < s.length; j++) {
  newS = s.replaceFirst(target, i++);
  j += newS.length - s.length;
  s = newS;
}

答案 3 :(得分:0)

这是一个解决方案:

    public static void main(String[] a) {

        int i = 1;
        String before = "aabbccaabbaabbaa";
        String regex = "aa";

        String after = substitute(i, before, regex);

        System.out.println(after);

    }

    private static String substitute(int i, String before, String regex) {

        String after = before.replaceFirst(regex, Integer.toString(i++));

        while (!before.equals(after)) {

            before = after;
            after = before.replaceFirst(regex, Integer.toString(i++));

        }

        return after;

    }

输出: 1bbcc2bb3bb4