替换多次出现的字符

时间:2013-05-22 08:50:48

标签: java regex

我找到了

String seq = "123456789";
    String regex = seq.replaceAll(".", "(?=[$0-9]([a-z]))?") + "[0-9][a-z]";
    String repl = seq.replaceAll(".", "\\$$0");

将4a变成aaaa,3b变成bbb等等......我需要反面而我无法理解它。我需要将aaaa变成4a,将bbb变成3b,依此类推。非常感谢

1 个答案:

答案 0 :(得分:1)

以下是Java中的行程编码/解码实现的示例:

import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class RunLengthEncoding {

    public static String encode(String source) {
        StringBuffer dest = new StringBuffer();
        for (int i = 0; i < source.length(); i++) {
            int runLength = 1;
            while (i+1 < source.length() && source.charAt(i) == source.charAt(i+1)) {
                runLength++;
                i++;
            }
            dest.append(runLength);
            dest.append(source.charAt(i));
        }
        return dest.toString();
    }

    public static String decode(String source) {
        StringBuffer dest = new StringBuffer();
        Pattern pattern = Pattern.compile("[0-9]+|[a-zA-Z]");
        Matcher matcher = pattern.matcher(source);
        while (matcher.find()) {
            int number = Integer.parseInt(matcher.group());
            matcher.find();
            while (number-- != 0) {
                dest.append(matcher.group());
            }
        }
        return dest.toString();
    }

    public static void main(String[] args) {
        String example = "WWWWWWWWWWWWBWWWWWWWWWWWWBBBWWWWWWWWWWWWWWWWWWWWWWWWBWWWWWWWWWWWWWW";
        System.out.println(encode(example));
        System.out.println(decode("1W1B1W1B1W1B1W1B1W1B1W1B1W1B"));
    }
}

从这里采取:

http://rosettacode.org/wiki/Run-length_encoding

(此页面包含72种不同编程语言中的等效示例,以实现相同的目标)

要实现您的要求,您可以使用“编码”方法。

在这里测试:http://www.browxy.com/SubmittedCode/21369

正则表达式本身并不适合尝试实现这一目标。