
- Groovy Tutorial
- Groovy - Home
- Groovy - Overview
- Groovy - Environment
- Groovy - Basic Syntax
- Groovy - Data Types
- Groovy - Variables
- Groovy - Optionals
- Groovy - Numbers
- Groovy - Strings
- Groovy - Ranges
- Groovy - Lists
- Groovy - Maps
- Groovy - Dates & Times
Groovy Operators
- Groovy - Operators
- Groovy - Arithmetic Operators
- Groovy - Assignment Operators
- Groovy - Relational Operators
- Groovy - Logical Operators
- Groovy - Bitwise Operators
- Groovy - Spaceship Operator
- Groovy - in Operator
- Groovy - Elvis Operator
- Groovy - Safe Navigation Operator
- Groovy Operator Precedence & Associativity
Control Statements
- Groovy - Decision Making
- Groovy - If Else Statement
- Groovy - Switch Statement
- Groovy - Loops
- Groovy - For Loop
- Groovy - For-in Loop
- Groovy - While Loop
- Groovy - Do While Loop
- Groovy - Break Statement
- Groovy - Continue Statement
Groovy File Handling
- Groovy - File I/O
- Java - Create a File
- Java - Write to File
- Java - Append to File
- Java - Read Files
- Java - Delete Files
- Java - File Properties
- Java - File Existence and Type
- Java - File Size
- Java - File Permissions
- Java - Directories
- Java - Listing Directories
- Java - Filtering Files/Directories
- Java - Deleting Directories
- Java - Renaming Files/Directories
Groovy Error & Exceptions
- Groovy - Exception Handling
- Groovy - try-catch Block
- Groovy - try-with-resources
- Groovy - Multi-catch Block
- Groovy - Nested try Block
- Groovy - Finally Block
- Groovy - throw Exception
- Groovy - Exception Propagation
- Groovy - Built-in Exceptions
- Groovy - Custom Exception
Groovy Multithreading
- groovy - Multithreading
- groovy - Thread Life Cycle
- groovy - Creating a Thread
- groovy - Starting a Thread
- groovy - Joining Threads
- groovy - Naming Thread
- groovy - Thread Scheduler
- groovy - Thread Pools
- groovy - Main Thread
- groovy - Thread Priority
- groovy - Daemon Threads
- groovy - Shutdown Hook
Groovy Synchronization
- groovy - Synchronization
- groovy - Block Synchronization
- groovy - Static Synchronization
- groovy - Inter-thread Communication
- groovy - Thread Deadlock
- groovy - Interrupting a Thread
- groovy - Thread Control
- groovy - Reentrant Monitor
- Groovy - Methods
- Groovy - Methods
- Groovy - Optional parenthesis
- Groovy - Named Arguments
- Groovy - Closures as Arguments
- Groovy - Method Overloading
- Groovy - Method Scope and Visibility
- Groovy - isCase Method
- Groovy - Implicit Return
- Groovy - Variable Arguments
- Groovy - Regular Expressions
- Groovy - Regular Expressions
- Groovy - Defining Regular Expressions
- Groovy - Matcher Object
- Groovy - Regex Tasks
- Groovy - XML
- Groovy - XML
- Groovy - Parsing XML
- Groovy - Creating XML
- Groovy - Modifying XML
- Groovy - Querying XML
- Groovy - Simplified Notation
- Groovy - Closure based Querying
- Groovy - Closure based Creation
- Groovy - JSON
- Groovy - JSON
- Groovy - Parsing JSON
- Groovy - Creating JSON using JsonOutput
- Groovy - Creating JSON using JsonBuilder
- Groovy - Modifying JSON
- Groovy - Error Handling
- Groovy - Handling JSON Arrays
- Groovy - JSON Array Operations
- Groovy - JSON Objects
- Groovy - JSON Object Operations
- Groovy - Generics
- Groovy - Generics
- Groovy - Declaring Generic Types
- Groovy - Bound Type Parameters
- Groovy - Wild Cards
- Groovy - Miscellaneous
- Groovy - Object Oriented
- Groovy - Closures
- Groovy - Annotations
- Groovy - JMX
- Groovy - DSLS
- Groovy - Database
- Groovy - Builders
- Groovy - Command Line
- Groovy - Unit Testing
- Groovy - Template Engines
- Groovy - Meta Object Programming
- Groovy Useful Resources
- Groovy - Quick Guide
- Groovy - Useful Resources
- Groovy - Discussion
Groovy - Closure based Quering XML
Groovy provides a very powerful and idomatic ways to query XML. We can use XmlSlurper which leverages heavily closures for querying XML. We can use filter, each and collect methods which accepts closure to define the quering logic.
Load and Parse existing XML document
Using XmlSlurper we can load the XML document in the application.
def xmlMovies = ''' <movies> <movie title = 'Enemy Behind'> <type>War, Thriller</type> <format>DVD</format> <year>2003</year> <director>John Adam</director> <rating>8</rating> <stars>PG</stars> </movie> <movie title = 'War Zone'> <type>War, Thriller</type> <format>DVD</format> <year>2013</year> <director>John Carry</director> <rating>4</rating> <stars>PG</stars> </movie> <movie title = 'Transformers'> <type>Anime, Science Fiction</type> <format>DVD</format> <year>1989</year> <director>Cooper</director> <rating>7</rating> <stars>R</stars> </movie> <movie title = 'Godzilla Plus One'> <type>Anime, Science Fiction</type> <format>DVD</format> <year>2024</year> <director>Cooper</director> <rating>9</rating> <stars>R</stars> </movie> </movies> ''' // parse xml into movies object def movies = new XmlSlurper().parseText(xmlMovies) // We can parse XML file as well // def movies = new XmlSlurper().parse(new File('movies.xml'))
Filter Movies by Rating
// Using a closure with 'findAll' to filter movies by ratings def highRatedMovies = movies.movie.findAll { movie -> movie.rating.toBigDecimal() > 7 } highRatedMovies.each { println "Highly Rated Moview: ${it.@title.text()} (${it.rating.text()})" }
Collect Movies Titles with Directors
// Using a closure with 'collect' to get titles with directors def titlesWithDirectors = movies.movie.collect { movie -> "${movie.@title.text()} by ${movie.director.text()}" } println "Titles with directors: $titlesWithDirectors"
Iterating Movies using each
// Using a closure with 'each' to perform an action on each movie movies.movie.each { movie -> println "Type: ${movie.type}, Title: ${movie.@title}" }
In above examples, the closures {movie -> ...} define the implementation logic to filter, transform and process each movie object. Closure receives GPathResult which represents the movie element and we can access elements and attibutes of the movie element in the closure.
Complete Example - Quering XML using Closures
def xmlMovies = ''' <movies> <movie title = 'Enemy Behind'> <type>War, Thriller</type> <format>DVD</format> <year>2003</year> <director>John Adam</director> <rating>8</rating> <stars>PG</stars> </movie> <movie title = 'War Zone'> <type>War, Thriller</type> <format>DVD</format> <year>2013</year> <director>John Carry</director> <rating>4</rating> <stars>PG</stars> </movie> <movie title = 'Transformers'> <type>Anime, Science Fiction</type> <format>DVD</format> <year>1989</year> <director>Cooper</director> <rating>7</rating> <stars>R</stars> </movie> <movie title = 'Godzilla Plus One'> <type>Anime, Science Fiction</type> <format>DVD</format> <year>2024</year> <director>Cooper</director> <rating>9</rating> <stars>R</stars> </movie> </movies> ''' // parse xml into movies object def movies = new XmlSlurper().parseText(xmlMovies) // Using a closure with 'findAll' to filter movies by ratings def highRatedMovies = movies.movie.findAll { movie -> movie.rating.toBigDecimal() > 7 } highRatedMovies.each { println "Highly Rated Moview: ${it.@title.text()} (${it.rating.text()})" } // Using a closure with 'collect' to get titles with directors def titlesWithDirectors = movies.movie.collect { movie -> "${movie.@title.text()} by ${movie.director.text()}" } println "Titles with directors: $titlesWithDirectors" // Using a closure with 'each' to perform an action on each movie movies.movie.each { movie -> println "Type: ${movie.type}, Title: ${movie.@title}" }
Output
When we run the above program, we will get the following result.
Highly Rated Moview: Enemy Behind (8) Highly Rated Moview: Godzilla Plus One (9) Titles with directors: [Enemy Behind by John Adam, War Zone by John Carry, Transformers by Cooper, Godzilla Plus One by Cooper] Type: War, Thriller, Title: Enemy Behind Type: War, Thriller, Title: War Zone Type: Anime, Science Fiction, Title: Transformers Type: Anime, Science Fiction, Title: Godzilla Plus One
Advertisements