I want to parse the following url: http://eutils.ncbi.nlm.nih.gov/entrez/eutils/esummary.fcgi?db=nucleotide&id=224589801
As a result I came up with the following method:
public void parseXml2(String URL) {
DOMParser parser = new DOMParser();
try {
parser.parse(new InputSource(new URL(URL).openStream()));
Document doc = parser.getDocument();
NodeList nodeList = doc.getElementsByTagName("Item");
for (int i = 0; i < nodeList.getLength(); i++) {
Node n = nodeList.item(i);
Node actualNode = n.getFirstChild();
if (actualNode != null) {
System.out.println(actualNode.getNodeValue());
}
}
} catch (SAXException ex) {
Logger.getLogger(TaxMapperXml.class.getName()).log(Level.SEVERE, null, ex);
} catch (IOException ex) {
Logger.getLogger(TaxMapperXml.class.getName()).log(Level.SEVERE, null, ex);
}
}
With this method I can take the values of the Item nodes but I can't take any of their attributes. I tried experimenting with getAttribute() with NamedNodeMap but still to no avail.
Why do I have to do
n.getFirstChild().getNodeValue();
to get the actual value?n.getNodeValue()
returns just null? Isn't this counter-intuitive - obviously in my case node's doesn't have subnodes?Is there some more robust and widely accepted way of parsing XML files using DOM? My files aren't gonna be big 15-20 lines at most, so SAX isn't necessary (or is it?)
Text value that is surrounded by XML tag are also considered as Node in DOM. That's why you have to get the text Node before getting the value. If you try to count the number of node in an
<Item>
, you will see that whenever there is a text, there is a node.XOM has more intuitive interface but it doesn't have
org.w3c.dom.*
interface.If you want to use the build-in parser, you should look at http://www.java-samples.com/showtutorial.php?tutorialid=152
The
DOMParser
you tried to use are propriety and it's not portable.Text inside xml elements are in text nodes because subelements can be mixed with text. For instance:
Element A has three children: a text node, element B, another text node.
Completed the sample code and added a few lines to get the attributes.
This should get you started, although I feel that you need to get yourself up to date with the basic notions of DOM. This site (and many others) can help you with that. Most importantly is understanding the different kinds of nodes there are.