使用Document Object Model, DOM解析XML文档
也可参考我的新浪博客:http://blog.sina.com.cn/s/blog_43ac5543010190w3.html
测试代码如下
package main; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NamedNodeMap; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import org.w3c.dom.Text; public class Test { public static void main(String[] args) throws Exception { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); factory.setIgnoringElementContentWhitespace(true); factory.setIgnoringComments(true); factory.setValidating(true); Document xmlDoc = builder.parse("C:/test.xml"); Element root = xmlDoc.getDocumentElement(); listNodes(root, ""); } public static void listNodes(Node node, String space) { Element element = null; // if (node instanceof Element) { if (node.getNodeType() == Node.ELEMENT_NODE) { element = (Element) node; Text textNode = (Text) element.getFirstChild(); String tagName = element.getTagName(); String tagValue = textNode.getData().trim(); System.out.print(space + tagName); if (!"".equals(tagValue)) { System.out.print("=" + tagValue); } NamedNodeMap attributes = element.getAttributes(); for (int i = 0; i < attributes.getLength(); i++) { Node attribute = attributes.item(i); String name = attribute.getNodeName(); String value = attribute.getNodeValue(); System.out.print(" " + name + ":" + value); } System.out.println(); } NodeList list = node.getChildNodes(); int childNodesLength = list.getLength(); if (childNodesLength > 0) { for (int i = 0; i < childNodesLength; i++) { listNodes(list.item(i), space + " "); } } } }