Java: 文字列内の一致の位置を取得する方法? 質問する

Java: 文字列内の一致の位置を取得する方法? 質問する
String match = "hello";
String text = "0123456789hello0123456789";

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

ベストアンサー1

これを実行するメソッド ファミリは次のとおりです。

この文字列内の最初の(または最後) 指定された部分文字列の出現 [前方検索 (または逆) を指定されたインデックスから開始します。


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"

おすすめ記事