Ejemplos prácticos de análisis (parsing) de XML
En esta sección, exploraremos algunos ejemplos prácticos de análisis de archivos XML utilizando las API de Java discutidas anteriormente.
Analizar un archivo XML simple
Comencemos con un archivo XML simple llamado books.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<library>
<book>
<title>The Great Gatsby</title>
<author>F. Scott Fitzgerald</author>
<year>1925</year>
</book>
<book>
<title>To Kill a Mockingbird</title>
<author>Harper Lee</author>
<year>1960</year>
</book>
</library>
Utilizando el analizador DOM, podemos analizar este archivo y extraer la información de los libros:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse("books.xml");
NodeList bookNodes = document.getElementsByTagName("book");
for (int i = 0; i < bookNodes.getLength(); i++) {
Node bookNode = bookNodes.item(i);
System.out.println("Title: " + bookNode.getElementsByTagName("title").item(0).getTextContent());
System.out.println("Author: " + bookNode.getElementsByTagName("author").item(0).getTextContent());
System.out.println("Year: " + bookNode.getElementsByTagName("year").item(0).getTextContent());
}
Analizar un archivo XML complejo
Ahora, consideremos un archivo XML más complejo que incluye espacios de nombres:
<?xml version="1.0" encoding="UTF-8"?>
<library xmlns="http://example.com/library"
xmlns:dc="http://purl.org/dc/elements/1.1/">
<book>
<dc:title>The Catcher in the Rye</dc:title>
<dc:creator>J.D. Salinger</dc:creator>
<dc:date>1951</dc:date>
</book>
<book>
<dc:title>1984</dc:title>
<dc:creator>George Orwell</dc:creator>
<dc:date>1949</dc:date>
</book>
</library>
Para analizar este archivo y acceder a los elementos con espacios de nombres, podemos utilizar el siguiente código:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
factory.setNamespaceAware(true);
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse("books.xml");
NodeList bookNodes = document.getElementsByTagNameNS("http://example.com/library", "book");
for (int i = 0; i < bookNodes.getLength(); i++) {
Node bookNode = bookNodes.item(i);
System.out.println("Title: " + bookNode.getElementsByTagNameNS("http://purl.org/dc/elements/1.1/", "title").item(0).getTextContent());
System.out.println("Author: " + bookNode.getElementsByTagNameNS("http://purl.org/dc/elements/1.1/", "creator").item(0).getTextContent());
System.out.println("Year: " + bookNode.getElementsByTagNameNS("http://purl.org/dc/elements/1.1/", "date").item(0).getTextContent());
}
Al entender estos ejemplos prácticos, ahora debería tener un conocimiento sólido de cómo analizar archivos XML utilizando las API de Java.