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]1を参照してください。

解説 (0)

string.indexOfを使用して、開始インデックスを取得します。

解説 (0)