Как создать функцию XPath в Groovy
Я пытаюсь создать функцию в Groovy, которая делает следующее:
- Принимает 2 параметра во время выполнения (строка XML и запрос xpath)
- Возвращает результат как текст
Это, вероятно, довольно просто, но для двух препятствий:
- Это нужно сделать в groovy
- Я ничего не знаю ничего о Groovy или Java...
Это, насколько я понял, взломав разные фрагменты кода, но теперь я застрял:
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.xpath.*;
builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
doc = builder.parse(new ByteArrayInputStream(xml.bytes));
expr = XPathFactory.newInstance().newXPath().compile(expression);
Object result = expr.evaluate(doc, XPathConstants.NODESET)
где "xml" и "expression" - это параметры времени выполнения. Как мне получить это сейчас, чтобы вернуть результат (как строку)?
Спасибо
Ответы
Ответ 1
Вы можете сделать что-то вроде этого:
import javax.xml.xpath.*
import javax.xml.parsers.DocumentBuilderFactory
def testxml = '''
<records>
<car name="HSV Maloo" make="Holden" year="2006">
<country>Australia</country>
<record type="speed">Production Pickup Truck with speed of 271kph</record>
</car>
</records>
'''
def processXml( String xml, String xpathQuery ) {
def xpath = XPathFactory.newInstance().newXPath()
def builder = DocumentBuilderFactory.newInstance().newDocumentBuilder()
def inputStream = new ByteArrayInputStream( xml.bytes )
def records = builder.parse(inputStream).documentElement
xpath.evaluate( xpathQuery, records )
}
println processXml( testxml, '//car/record/@type' )
Посмотрите на эту страницу (ранее являющуюся частью Groovy Docs) для того, как обрабатывать запросы XPath, которые возвращают несколько результатов:
http://groovy.jmiguel.eu/groovy.codehaus.org/Reading+XML+with+Groovy+and+XPath.html
Ответ 2
Это то, что я в конце концов решил, что должно работать для моих целей:
import javax.xml.xpath.*
import javax.xml.parsers.DocumentBuilderFactory
def processXml( String xml, String xpathQuery ) {
def xpath = XPathFactory.newInstance().newXPath()
def builder = DocumentBuilderFactory.newInstance().newDocumentBuilder()
def inputStream = new ByteArrayInputStream( xml.bytes )
def records = builder.parse(inputStream).documentElement
def nodes = xpath.evaluate( xpathQuery, records, XPathConstants.NODESET )
nodes.collect { node -> node.textContent }
}
processXml( xml, query )