Extract overlapping matches using split

前端 未结 3 1601
广开言路
广开言路 2021-01-06 16:22

How can I extract overlapping matches from an input using String.split()?

For example, if trying to find matches to \"aba\":



        
3条回答
  •  不思量自难忘°
    2021-01-06 16:56

    String#split will not give you overlapping matches. Because a particular part of the string, will only be included in a unique index, of the array obtained, and not in two indices.

    You should use Pattern and Matcher classes here. You can use this regex: -

    Pattern pattern = Pattern.compile("(?=(aba))");
    

    And use Matcher#find method to get all the overlapping matches, and print group(1) for it.

    The above regex matches every empty string, that is followed by aba, then just print the 1st captured group. Now since look-ahead is zero-width assertion, so it will not consume the string that is matched. And hence you will get all the overlapping matches.

    String input = "abababa";
    String patternToFind = "aba";
    
    Pattern pattern = Pattern.compile("(?=" + patternToFind + ")");
    Matcher matcher = pattern.matcher(input);
    
    while (matcher.find()) {
        System.out.println(patternToFind + " found at index: " + matcher.start());
    }
    

    Output: -

    aba found at index: 0
    aba found at index: 2
    aba found at index: 4
    

提交回复
热议问题