Entiendo por Google que tiene más sentido extraer datos de XML utilizando XPath que utilizando el bucle DOM.Looping sobre nodos y extracción de valores de subnodos específicos utilizando XPath de Java
Por el momento, he implementado una solución usando DOM, pero el código es detallado, y se siente desordenado y no se puede mantener, así que me gustaría cambiar a una solución XPath más limpia.
Digamos que tengo esta estructura:
<products>
<product>
<title>Some title 1</title>
<image>Some image 1</image>
</product>
<product>
<title>Some title 2</title>
<image>Some image 2</image>
</product>
...
</products>
Quiero ser capaz de ejecutar un bucle para cada uno de los <product>
elementos, y dentro de este bucle, extraer los valores de los nodos de título y de imagen.
Mi código es el siguiente:
InputStream is = conn.getInputStream();
DocumentBuilder builder =
DocumentBuilderFactory.newInstance().newDocumentBuilder();
Document doc = builder.parse(is);
XPathFactory factory = XPathFactory.newInstance();
XPath xpath = factory.newXPath();
XPathExpression expr = xpath.compile("/products/product");
Object result = expr.evaluate(doc, XPathConstants.NODESET);
NodeList products = (NodeList) result;
for (int i = 0; i < products.getLength(); i++) {
Node n = products.item(i);
if (n != null && n.getNodeType() == Node.ELEMENT_NODE) {
Element product = (Element) n;
// do some DOM navigation to get the title and image
}
}
Dentro de mi bucle for
me sale cada <product>
como Node
, que se convierte en una Element
.
¿Puedo simplemente usar mi instancia de XPathExpression
para compilar y ejecutar otro XPath
en el Node
o la Element
?