在每个 n 个位置拆分一个字符串

2022-09-01 11:12:57

我使用此正则表达式在每个说第3个位置拆分一个字符串:

String []thisCombo2 = thisCombo.split("(?<=\\G...)");

其中 G 后面的 3 个点表示要拆分的第 n 个位置。在本例中,3 个点表示每 3 个位置。例如:

Input: String st = "123124125134135145234235245"
Output: 123 124 125 134 135 145 234 235 245.

我的问题是,我如何让用户控制字符串必须拆分的位置数量?换句话说,我如何使这3个点,n个点由用户控制?


答案 1

对于重大的性能改进,另一种方法是在循环中使用:substring()

public String[] splitStringEvery(String s, int interval) {
    int arrayLength = (int) Math.ceil(((s.length() / (double)interval)));
    String[] result = new String[arrayLength];

    int j = 0;
    int lastIndex = result.length - 1;
    for (int i = 0; i < lastIndex; i++) {
        result[i] = s.substring(j, j + interval);
        j += interval;
    } //Add the last bit
    result[lastIndex] = s.substring(j);

    return result;
}

例:

Input:  String st = "1231241251341351452342352456"
Output: 123 124 125 134 135 145 234 235 245 6.

它不像stevevls的解决方案那么短,但它更有效率(见下文),我认为将来调整起来会更容易,当然这取决于你的情况。


性能测试 (Java 7u45)

2,000 个字符长的字符串 - 间隔为 3

split("(?<=\\G.{" + count + "})")性能(以毫秒为单位):

7, 7, 5, 5, 4, 3, 3, 2, 2, 2

splitStringEvery() (substring()) 性能(以毫秒为单位):

2, 0, 0, 0, 0, 1, 0, 1, 0, 0

2,000,000 个字符长的字符串 - 间隔为 3

split()性能(以毫秒为单位):

207, 95, 376, 87, 97, 83, 83, 82, 81, 83

splitStringEvery()性能(以毫秒为单位):

44, 20, 13, 24, 13, 26, 12, 38, 12, 13

2,000,000 个字符长的字符串 - 间隔为 30

split()性能(以毫秒为单位):

103, 61, 41, 55, 43, 44, 49, 47, 47, 45

splitStringEvery()性能(以毫秒为单位):

7, 7, 2, 5, 1, 3, 4, 4, 2, 1

结论:

该方法要快得多(即使在Java 7u6中发生更改之后),并且当间隔变高时,它会升级splitStringEvery()

即用型测试代码:

pastebin.com/QMPgLbG9


答案 2

可以使用大括号运算符指定字符必须出现的次数:

String []thisCombo2 = thisCombo.split("(?<=\\G.{" + count + "})");

大括号是一个方便的工具,因为您可以使用它来指定确切的计数或范围。