Java:如何获取字符串中的匹配位置?

String match = "hello";
String text = "0123456789hello0123456789";

int position = getPosition(match, text); // should be 10, is there such a method?
解决办法

做到这一点的方法系列有:。

返回指定子串第一次(或最后一次)出现在这个字符串中的索引[从指定索引开始向前(或向后)搜索]。


String text = "0123hello9012hello8901hello7890";
String word = "hello";

System.out.println(text.indexOf(word)); // prints "4"
System.out.println(text.lastIndexOf(word)); // prints "22"

// find all occurrences forward
for (int i = -1; (i = text.indexOf(word, i + 1)) != -1; i++) {
    System.out.println(i);
} // prints "4", "13", "22"

// find all occurrences backward
for (int i = text.length(); (i = text.lastIndexOf(word, i - 1)) != -1; i++) {
    System.out.println(i);
} // prints "22", "13", "4"
评论(4)
text.indexOf(match);

String javadoc

评论(0)

使用string.indexOf来获得起始索引。

评论(0)