Hans Wiener
Hans Wiener

Reputation: 129

Java: Find index of first Regex

I need to change a piece of code which includes this:

string.indexOf("bc")

How can this be changed by a solution that skips the occurrence of "bc" if it is preceded by the letter "a".

I don't want to find these:

abc

but only:

xbc

where x can be anything but a (even empty).

I think I could just put in a condition that checks if the index i-1 == a, and if true call the indexOf method again. But I don't think that would result in very beautiful code.

How would a solution that uses regular expressions look like?

Edit: Just a hint after seeing some responses. It would be nice to get not only the regular expression, but also the required API calls to find the index.

Upvotes: 9

Views: 30546

Answers (4)

Andre Nel
Andre Nel

Reputation: 442

To add to Arne's answer - if you wanted to also add indexing:

public static int indexOf(String regex, String s, int index)
{
    Pattern pattern = Pattern.compile(regex);
    Matcher matcher = pattern.matcher(s);
    return matcher.find(index) ? matcher.start() : -1;
}

call:

int index = indexOf("(?<!a)bc", "abc xbc", 2);

Upvotes: 2

Arne
Arne

Reputation: 2146

As requested a more complete solution:

    /** @return index of pattern in s or -1, if not found */
public static int indexOf(Pattern pattern, String s) {
    Matcher matcher = pattern.matcher(s);
    return matcher.find() ? matcher.start() : -1;
}

call:

int index = indexOf(Pattern.compile("(?<!a)bc"), "abc xbc");

Upvotes: 19

kennytm
kennytm

Reputation: 523784

You could use a regex with a negative lookbehind:

(?<!a)bc

Unfortunately to reproduce .indexOf with Regex in Java is still a mess:

Pattern pattern = Pattern.compile("(?!a)bc");
Matcher matcher = pattern.matcher("abc xbc");
if (matcher.find()) {
    return matcher.start();
}

Upvotes: 5

Roddy of the Frozen Peas
Roddy of the Frozen Peas

Reputation: 15219

Use regex to find the String that matches your criteria, and then find the index of that String.

int index = -1;
Pattern p = Pattern.compile("[^Aa]?bc");
Matcher m = p.matcher(string);
if (m.find()) {
    index = m.start();
}

Something like this. Where 'string' is the text you're searching and 'index' holds the location of the string that is found. (index will be -1 if not found.) Also note that the pattern is case sensitive unless you set a flag.

Upvotes: 1

Related Questions