Package groovy.xml
Class XmlSlurper
java.lang.Object
org.xml.sax.helpers.DefaultHandler
groovy.xml.XmlSlurper
- All Implemented Interfaces:
- org.xml.sax.ContentHandler,- org.xml.sax.DTDHandler,- org.xml.sax.EntityResolver,- org.xml.sax.ErrorHandler
public class XmlSlurper
extends org.xml.sax.helpers.DefaultHandler
Parse XML into a document tree that may be traversed similar to XPath
 expressions.  For example:
 
 import groovy.xml.XmlSlurper
 def rootNode = new XmlSlurper().parseText(
    '<root><one a1="uno!"/><two>Some text!</two></root>' )
 assert rootNode.name() == 'root'
 assert rootNode.one[0].@a1 == 'uno!'
 assert rootNode.two.text() == 'Some text!'
 rootNode.children().each { assert it.name() in ['one','two'] }
 
 Note that in some cases, a 'selector' expression may not resolve to a single node. For example:
 import groovy.xml.XmlSlurper
 def rootNode = new XmlSlurper().parseText(
    '''<root>
         <a>one!</a>
         <a>two!</a>
       </root>''' )
 assert rootNode.a.size() == 2
 rootNode.a.each { assert it.text() in ['one!','two!'] }
 - See Also:
- GPathResult
- 
Constructor SummaryConstructors Constructor Description XmlSlurper()Creates a non-validating and namespace-awareXmlSlurperwhich does not allow DOCTYPE declarations in documents.XmlSlurper(boolean validating, boolean namespaceAware)Creates aXmlSlurperwhich does not allow DOCTYPE declarations in documents.XmlSlurper(boolean validating, boolean namespaceAware, boolean allowDocTypeDeclaration)Creates aXmlSlurper.XmlSlurper(javax.xml.parsers.SAXParser parser)XmlSlurper(org.xml.sax.XMLReader reader)
- 
Method SummaryModifier and Type Method Description voidcharacters(char[] ch, int start, int length)voidendDocument()voidendElement(java.lang.String namespaceURI, java.lang.String localName, java.lang.String qName)GPathResultgetDocument()org.xml.sax.DTDHandlergetDTDHandler()org.xml.sax.EntityResolvergetEntityResolver()org.xml.sax.ErrorHandlergetErrorHandler()booleangetFeature(java.lang.String uri)java.lang.ObjectgetProperty(java.lang.String uri)voidignorableWhitespace(char[] buffer, int start, int len)booleanisKeepIgnorableWhitespace()GPathResultparse(java.io.File file)Parses the content of the given file as XML turning it into a GPathResult objectGPathResultparse(java.io.InputStream input)Parse the content of the specified input stream into an GPathResult Object.GPathResultparse(java.io.Reader in)Parse the content of the specified reader into a GPathResult Object.GPathResultparse(java.lang.String uri)Parse the content of the specified URI into a GPathResult ObjectGPathResultparse(java.nio.file.Path path)GPathResultparse(org.xml.sax.InputSource input)Parse the content of the specified input source into a GPathResult objectGPathResultparseText(java.lang.String text)A helper method to parse the given text as XMLvoidsetDTDHandler(org.xml.sax.DTDHandler dtdHandler)voidsetEntityBaseUrl(java.net.URL base)Resolves entities against using the supplied URL as the base for relative URLsvoidsetEntityResolver(org.xml.sax.EntityResolver entityResolver)voidsetErrorHandler(org.xml.sax.ErrorHandler errorHandler)voidsetFeature(java.lang.String uri, boolean value)voidsetKeepIgnorableWhitespace(boolean keepIgnorableWhitespace)voidsetKeepWhitespace(boolean keepWhitespace)Deprecated.use setKeepIgnorableWhitespacevoidsetProperty(java.lang.String uri, java.lang.Object value)voidstartDocument()voidstartElement(java.lang.String namespaceURI, java.lang.String localName, java.lang.String qName, org.xml.sax.Attributes atts)voidstartPrefixMapping(java.lang.String tag, java.lang.String uri)Methods inherited from class org.xml.sax.helpers.DefaultHandlerendPrefixMapping, error, fatalError, notationDecl, processingInstruction, resolveEntity, setDocumentLocator, skippedEntity, unparsedEntityDecl, warningMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.xml.sax.ContentHandlerdeclaration
- 
Constructor Details- 
XmlSlurperpublic XmlSlurper() throws javax.xml.parsers.ParserConfigurationException, org.xml.sax.SAXExceptionCreates a non-validating and namespace-awareXmlSlurperwhich does not allow DOCTYPE declarations in documents.- Throws:
- javax.xml.parsers.ParserConfigurationException- if no parser which satisfies the requested configuration can be created.
- org.xml.sax.SAXException- for SAX errors.
 
- 
XmlSlurperpublic XmlSlurper(boolean validating, boolean namespaceAware) throws javax.xml.parsers.ParserConfigurationException, org.xml.sax.SAXExceptionCreates aXmlSlurperwhich does not allow DOCTYPE declarations in documents.- Parameters:
- validating-- trueif the parser should validate documents as they are parsed; false otherwise.
- namespaceAware-- trueif the parser should provide support for XML namespaces;- falseotherwise.
- Throws:
- javax.xml.parsers.ParserConfigurationException- if no parser which satisfies the requested configuration can be created.
- org.xml.sax.SAXException- for SAX errors.
 
- 
XmlSlurperpublic XmlSlurper(boolean validating, boolean namespaceAware, boolean allowDocTypeDeclaration) throws javax.xml.parsers.ParserConfigurationException, org.xml.sax.SAXExceptionCreates aXmlSlurper.- Parameters:
- validating-- trueif the parser should validate documents as they are parsed; false otherwise.
- namespaceAware-- trueif the parser should provide support for XML namespaces;- falseotherwise.
- allowDocTypeDeclaration-- trueif the parser should provide support for DOCTYPE declarations;- falseotherwise.
- Throws:
- javax.xml.parsers.ParserConfigurationException- if no parser which satisfies the requested configuration can be created.
- org.xml.sax.SAXException- for SAX errors.
 
- 
XmlSlurperpublic XmlSlurper(org.xml.sax.XMLReader reader)
- 
XmlSlurperpublic XmlSlurper(javax.xml.parsers.SAXParser parser) throws org.xml.sax.SAXException- Throws:
- org.xml.sax.SAXException
 
 
- 
- 
Method Details- 
setKeepWhitespace@Deprecated public void setKeepWhitespace(boolean keepWhitespace)Deprecated.use setKeepIgnorableWhitespace- Parameters:
- keepWhitespace- If true then whitespace before elements is kept. The default is to discard the whitespace.
 
- 
setKeepIgnorableWhitespacepublic void setKeepIgnorableWhitespace(boolean keepIgnorableWhitespace)- Parameters:
- keepIgnorableWhitespace- If true then ignorable whitespace (i.e. whitespace before elements) is kept. The default is to discard the whitespace.
 
- 
isKeepIgnorableWhitespacepublic boolean isKeepIgnorableWhitespace()- Returns:
- true if ignorable whitespace is kept
 
- 
getDocument- Returns:
- The GPathResult instance created by consuming a stream of SAX events Note if one of the parse methods has been called then this returns null Note if this is called more than once all calls after the first will return null
 
- 
parsepublic GPathResult parse(org.xml.sax.InputSource input) throws java.io.IOException, org.xml.sax.SAXExceptionParse the content of the specified input source into a GPathResult object- Parameters:
- input- the InputSource to parse
- Returns:
- An object which supports GPath expressions
- Throws:
- org.xml.sax.SAXException- Any SAX exception, possibly wrapping another exception.
- java.io.IOException- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.
 
- 
parseParses the content of the given file as XML turning it into a GPathResult object- Parameters:
- file- the File to parse
- Returns:
- An object which supports GPath expressions
- Throws:
- org.xml.sax.SAXException- Any SAX exception, possibly wrapping another exception.
- java.io.IOException- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.
 
- 
parsepublic GPathResult parse(java.io.InputStream input) throws java.io.IOException, org.xml.sax.SAXExceptionParse the content of the specified input stream into an GPathResult Object. Note that using this method will not provide the parser with any URI for which to find DTDs etc. It is up to you to close the InputStream after parsing is complete (if required).- Parameters:
- input- the InputStream to parse
- Returns:
- An object which supports GPath expressions
- Throws:
- org.xml.sax.SAXException- Any SAX exception, possibly wrapping another exception.
- java.io.IOException- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.
 
- 
parseParse the content of the specified reader into a GPathResult Object. Note that using this method will not provide the parser with any URI for which to find DTDs etc. It is up to you to close the Reader after parsing is complete (if required).- Parameters:
- in- the Reader to parse
- Returns:
- An object which supports GPath expressions
- Throws:
- org.xml.sax.SAXException- Any SAX exception, possibly wrapping another exception.
- java.io.IOException- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.
 
- 
parsepublic GPathResult parse(java.lang.String uri) throws java.io.IOException, org.xml.sax.SAXExceptionParse the content of the specified URI into a GPathResult Object- Parameters:
- uri- a String containing the URI to parse
- Returns:
- An object which supports GPath expressions
- Throws:
- org.xml.sax.SAXException- Any SAX exception, possibly wrapping another exception.
- java.io.IOException- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.
 
- 
parsepublic GPathResult parse(java.nio.file.Path path) throws java.io.IOException, org.xml.sax.SAXException- Throws:
- java.io.IOException
- org.xml.sax.SAXException
 
- 
parseTextpublic GPathResult parseText(java.lang.String text) throws java.io.IOException, org.xml.sax.SAXExceptionA helper method to parse the given text as XML- Parameters:
- text- a String containing XML to parse
- Returns:
- An object which supports GPath expressions
- Throws:
- org.xml.sax.SAXException- Any SAX exception, possibly wrapping another exception.
- java.io.IOException- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.
 
- 
getDTDHandlerpublic org.xml.sax.DTDHandler getDTDHandler()
- 
getEntityResolverpublic org.xml.sax.EntityResolver getEntityResolver()
- 
getErrorHandlerpublic org.xml.sax.ErrorHandler getErrorHandler()
- 
getFeaturepublic boolean getFeature(java.lang.String uri) throws org.xml.sax.SAXNotRecognizedException, org.xml.sax.SAXNotSupportedException- Throws:
- org.xml.sax.SAXNotRecognizedException
- org.xml.sax.SAXNotSupportedException
 
- 
getPropertypublic java.lang.Object getProperty(java.lang.String uri) throws org.xml.sax.SAXNotRecognizedException, org.xml.sax.SAXNotSupportedException- Throws:
- org.xml.sax.SAXNotRecognizedException
- org.xml.sax.SAXNotSupportedException
 
- 
setDTDHandlerpublic void setDTDHandler(org.xml.sax.DTDHandler dtdHandler)
- 
setEntityResolverpublic void setEntityResolver(org.xml.sax.EntityResolver entityResolver)
- 
setEntityBaseUrlpublic void setEntityBaseUrl(java.net.URL base)Resolves entities against using the supplied URL as the base for relative URLs- Parameters:
- base- The URL used to resolve relative URLs
 
- 
setErrorHandlerpublic void setErrorHandler(org.xml.sax.ErrorHandler errorHandler)
- 
setFeaturepublic void setFeature(java.lang.String uri, boolean value) throws org.xml.sax.SAXNotRecognizedException, org.xml.sax.SAXNotSupportedException- Throws:
- org.xml.sax.SAXNotRecognizedException
- org.xml.sax.SAXNotSupportedException
 
- 
setPropertypublic void setProperty(java.lang.String uri, java.lang.Object value) throws org.xml.sax.SAXNotRecognizedException, org.xml.sax.SAXNotSupportedException- Throws:
- org.xml.sax.SAXNotRecognizedException
- org.xml.sax.SAXNotSupportedException
 
- 
startDocumentpublic void startDocument() throws org.xml.sax.SAXException- Specified by:
- startDocumentin interface- org.xml.sax.ContentHandler
- Overrides:
- startDocumentin class- org.xml.sax.helpers.DefaultHandler
- Throws:
- org.xml.sax.SAXException
 
- 
startPrefixMappingpublic void startPrefixMapping(java.lang.String tag, java.lang.String uri) throws org.xml.sax.SAXException- Specified by:
- startPrefixMappingin interface- org.xml.sax.ContentHandler
- Overrides:
- startPrefixMappingin class- org.xml.sax.helpers.DefaultHandler
- Throws:
- org.xml.sax.SAXException
 
- 
startElementpublic void startElement(java.lang.String namespaceURI, java.lang.String localName, java.lang.String qName, org.xml.sax.Attributes atts) throws org.xml.sax.SAXException- Specified by:
- startElementin interface- org.xml.sax.ContentHandler
- Overrides:
- startElementin class- org.xml.sax.helpers.DefaultHandler
- Throws:
- org.xml.sax.SAXException
 
- 
ignorableWhitespacepublic void ignorableWhitespace(char[] buffer, int start, int len) throws org.xml.sax.SAXException- Specified by:
- ignorableWhitespacein interface- org.xml.sax.ContentHandler
- Overrides:
- ignorableWhitespacein class- org.xml.sax.helpers.DefaultHandler
- Throws:
- org.xml.sax.SAXException
 
- 
characterspublic void characters(char[] ch, int start, int length) throws org.xml.sax.SAXException- Specified by:
- charactersin interface- org.xml.sax.ContentHandler
- Overrides:
- charactersin class- org.xml.sax.helpers.DefaultHandler
- Throws:
- org.xml.sax.SAXException
 
- 
endElementpublic void endElement(java.lang.String namespaceURI, java.lang.String localName, java.lang.String qName) throws org.xml.sax.SAXException- Specified by:
- endElementin interface- org.xml.sax.ContentHandler
- Overrides:
- endElementin class- org.xml.sax.helpers.DefaultHandler
- Throws:
- org.xml.sax.SAXException
 
- 
endDocumentpublic void endDocument() throws org.xml.sax.SAXException- Specified by:
- endDocumentin interface- org.xml.sax.ContentHandler
- Overrides:
- endDocumentin class- org.xml.sax.helpers.DefaultHandler
- Throws:
- org.xml.sax.SAXException
 
 
-