In Java, Matcher is a class that is implemented by the MatchResult interface, that performs match operations on a character sequence by interpreting a Pattern.
Below, we can see the declaration of java.util.regex.Matcher in java.lang.Object Class:
public final class Matcher extends Object implements MatchResult
By invoking the pattern’s matcher method, a matcher is created from a pattern. If a matcher is created once, we can perform three different kinds of match operations on it:
- matches(): Try to match the total input sequence against the pattern.
- lookingAt(): Try to match the input sequence, against the pattern, starting at the beginning.
- find(): This scans the input sequence and looks for the next subsequence especially matches the pattern.
Methods of Matcher class:
Below the methods of the Matcher class are grouped in the table for convenience according to their functionality.
1. Index Methods:
It provides useful index values. It shows precisely whether the match was found in the input string or not:
S. No. | Method Name | Description |
---|---|---|
1 | public int start() | This method returns the start index of the previous match. |
2 | public int start(int group) | This method returns the start index of the subsequence captured by the given group during the previous match operation. |
3 | public int end() | This method returns the offset after the last character is matched. |
4 | public int end(int group) | This method returns the offset after the last character of the subsequence captured by the given group during the previous match operation. |
2. Study Methods:
It reviews the input string and returns a boolean indicating whether the pattern is found or not:
S. No. | Method Name | Description |
---|---|---|
1 | public boolean lookingAt() | This method aims to match the input sequence, starting at the beginning of the region, against the pattern. |
2 | public boolean find() | This method aims to find the next subsequence of the input sequence that matches the pattern. |
3 | public boolean find(int start) | Resets this matcher and then tries to find the next subsequence of the input sequence which matches the pattern, starting at the specified index. |
4 | public boolean matches() | This method aims to match the entire region against the pattern. |
3. Replacement Methods:
These are useful methods for replacing text in an input string:
S. No. | Method Name | Description |
---|---|---|
1 | public Matcher appendReplacement(StringBuffer sb, String replacement) | This method implements a non-terminal append-and-replace step. |
2 | public StringBuffer appendTail(StringBuffer sb) | This method implements a terminal append-and-replace step. |
3 | public String replaceAll(String replacement) | This method replaces every subsequence of the input sequence that matches the pattern with the given replacement string. |
4 | public String replaceFirst(String replacement) | This method replaces the first subsequence of the input sequence that matches the pattern with the given replacement string. |
5 | public static String quoteReplacement(String s) | This method returns a literal replacement String for the specified String, this method also produces a String which will work in the appendReplacement method as a literal replacement of the Matcher class. |
Example 1: Here we can see the example GFG.java which count the number of times the word “geek” appears in the input string using start() and end() :
// Java program to demonstrate the // methods of Matcher class in Java import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class GFG {
private static final String REGEX = "\\bgeek\\b" ;
private static final String INPUT
= "geek geek geek geekie geeks" ;
public static void main(String[] args)
{
Pattern pat = Pattern.compile(REGEX);
// here get a matcher object
Matcher mat = pat.matcher(INPUT);
// initialize a count variable to count
int count = 0 ;
// try to match the entire input sequence against
// the pattern using the loop
while (mat.find()) {
count++;
System.out.println( "Match number " + count);
System.out.println( "start(): " + mat.start());
System.out.println( "end(): " + mat.end());
}
}
} |
Match number 1 start(): 0 end(): 4 Match number 2 start(): 5 end(): 9 Match number 3 start(): 10 end(): 14
Example 2: In this example, we can see GFG.java, the lookingAt() and matches() both attempt to match an input sequence against a pattern.
// Java program to demonstrate the // methods of Matcher class in Java import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class GFG {
private static final String REGEX = "geek" ;
private static final String INPUT = "geeksforgeeks" ;
private static Pattern pat;
private static Matcher mat;
public static void main(String[] args)
{
// Initialization for pattern and matcher
pat = Pattern.compile(REGEX);
mat = pat.matcher(INPUT);
System.out.println( "Current REGEX: " + REGEX);
System.out.println( "Current INPUT: " + INPUT);
System.out.println( "lookingAt(): "
+ mat.lookingAt());
System.out.println( "matches(): " + mat.matches());
}
} |
Current REGEX: geek Current INPUT: geeksforgeeks lookingAt(): true matches(): false