Preface
In a previous post we learned how to create a java.util.regex.Pattern object. Now we learn how to create a java.util.regex.Matcher object and use it for finding and matching values.
In Groovy we use the =~ operator (find operator) to create a new matcher object. If the matcher has any match results we can access the results by invoking methods on the matcher object. But Groovy wouldn't by groovy if we could access the results easier. Groovy enhances the Matcher class so the data is available with an array-like syntax. If we use groups in the matcher the result can be accessed with a multidimensional array. Although the result of the =~operator is a matcher object in a conditional statement the result will be converted to a Boolean values.
We can use a second operator, ==~ (match operator), to do exact matches. With this operator the matches() method is invoked on the matcher object. The result is a Boolean value.
Sample Code
- def finder = ('groovy' =~ /gr.*/)
- assert finder instanceof java.util.regex.Matcher
- def matcher = ('groovy' ==~ /gr.*/)
- assert matcher instanceof Boolean
- assert 'Groovy rocks!' =~ /Groovy/ // =~ in conditional context returns boolean.
- assert !('Groovy rocks!' ==~ /Groovy/) // ==~ looks for an exact match.
- assert 'Groovy rocks!' ==~ /Groovy.*/
- def cool = /gr\w{4}/ // Start with gr followed by 4 characters.
- def findCool = ('groovy, java and grails rock!' =~ /$cool/)
- assert 2 == findCool.count
- assert 2 == findCool.size() // Groovy adds size() method.
- assert 'groovy' == findCool[0] // Array-like access to match results.
- assert 'grails' == findCool.getAt(1)
- // With grouping we get a multidimensional array.
- def group = ('groovy and grails, ruby and rails' =~ /(\w+) and (\w+)/)
- assert group.hasGroup()
- assert 2 == group.size()
- assert ['groovy and grails', 'groovy', 'grails'] == group[0]
- assert 'rails' == group[1][2]
- // Use matcher methods.
- assert 'Hi world' == ('Hello world' =~ /Hello/).replaceFirst('Hi')
- // Groovy matcher syntax can be used in other methods.
- assert ['abc'] == ['def', 'abc', '123'].findAll { it =~ /abc/ }
- assert [false, false, true] == ['def', 'abc', '123'].collect { it ==~ /\d{3}/ }
* [ In Action ] The Simple Groovy datatypes - Working with regular expressions
* Groovy Goodness: Using Regular Expression Pattern Class
* Groovy Goodness: Remove Part of String With Regular Expression Pattern
* Groovy Goodness: Partial Matches
* Grails Goodness: Checking Results from Forward Action in Controller Unit Tests
* Groovy Goodness: the Switch Statement
沒有留言:
張貼留言