import java.io.File; import java.util.List; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; /** * 遍历xml所有节点(包括子节点下还有子节点多层嵌套) */ public class TestXML { public static void main(final String[] args) { final TestXML test = new TestXML(); try { test.testGetRoot(); } catch (final Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } /** * 获取文件的xml对象,然后获取对应的根节点root */ public void testGetRoot() throws Exception { final SAXReader sax = new SAXReader();// 创建一个SAXReader对象 final File xmlFile = new File("C:\Users\.yang\Desktop\ss.xml");// 根据指定的路径创建file对象 final Document document = sax.read(xmlFile);// 获取document对象,如果文档无节点,则会抛出Exception提前结束 final Element root = document.getRootElement();// 获取根节点 getNodes(root);// 从根节点开始遍历所有节点 } /** * 从指定节点Element node开始,递归遍历其所有子节点 */ public void getNodes(final Element node) { System.out.println("-------开始新节点-------------"); // 当前节点的名称、文本内容和属性 System.out.println("当前节点名称:" + node.getName());// 当前节点名称 System.out.println("当前节点的内容:" + node.getTextTrim());// 当前节点内容 final List<Attribute> listAttr = node.attributes();// 当前节点的所有属性 for (final Attribute attr : listAttr) {// 遍历当前节点的所有属性 final String name = attr.getName();// 属性名称 final String value = attr.getValue();// 属性的值 System.out.println("属性名称:" + name + "---->属性值:" + value); } // 递归遍历当前节点所有的子节点 final List<Element> listElement = node.elements();// 所有一级子节点的list for (final Element e : listElement) {// 遍历所有一级子节点 getNodes(e);// 递归 } } }
参考文章:https://blog.csdn.net/sidihuo/article/details/47318723