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)