Dom4j递归遍历XML所有元素

版权声明:原创作品,允许转载,转载时请务必以超链接形式标明文章
原始出处 、作者信息和本声明。否则将追究法律责任。
http://lavasoft.blog.51cto.com/62575/71669
|
Java递归遍历XML所有元素
做一个递归遍历XML的例子,为更为复杂的解析工作做基础。
目标:遍历所有的元素节点,并且取出来其中的值,结果打印到控制台。
源代码如下:
本程序依赖DOM4j包。
import org.dom4j.Document;
import org.dom4j.DocumentHelper; import org.dom4j.DocumentException; import org.dom4j.Element; import java.util.*; /** * Created by IntelliJ IDEA.<br> * <b>User</b>: leizhimin<br> * <b>Date</b>: 2008-4-14 14:02:12<br> * <b>Note</b>: Java递归遍历XML所有元素 */ public class XmlTest { // private static Map<String, String> xmlmap = new HashMap<String, String>(); //存储xml元素信息的容器 private static List<Leaf> elemList = new ArrayList<Leaf>(); //要测试的xml对象 private static String srcXml = "<?xml version=\"1.0\" encoding=\"GBK\"?>\n" + "<doc>\n" + " <person>\n" + " <name>某人</name>\n" + " <adds> \n" + " <add ID=\"10002\">\n" + " <BS>10002</BS>\n" + " <note>西安市太白路</note>\n" + " </add>\n" + " <add ID=\"\">\n" + " <BS>10002</BS>\n" + " <note>空ID节点啊</note>\n" + " </add>\n" + " <add>\n" + " <BS>10002</BS>\n" + " <note>空ID节点啊</note>\n" + " </add>\n" + "\t\t\t<add ID=\"10001\">\n" + "\t\t\t\t<BS xmlns=\"10001\"/>\n" + " <note>西安市太白路2</note>\n" + " </add>\n" + "\t\t</adds>\n" + " </person>\n" + " <other>\n" + " <name ID=\"HEHE\">ASDF</name>\n" + " </other>\n" + "</doc>"; public static void main(String args[]) throws DocumentException { XmlTest test = new XmlTest(); Element root = test.getRootElement(); test.getElementList(root); String x = test.getListString(elemList); System.out.println( "-----------原xml内容------------"); System.out.println(srcXml); System.out.println( "-----------解析结果------------"); System.out.println(x); } /** * 获取根元素 * * @return * @throws DocumentException */ public Element getRootElement() throws DocumentException { Document srcdoc = DocumentHelper.parseText(srcXml); Element elem = srcdoc.getRootElement(); return elem; } /** * 递归遍历方法 * * @param element */ public void getElementList(Element element) { List elements = element.elements(); if (elements.size() == 0) { //没有子元素 String xpath = element.getPath(); String value = element.getTextTrim(); elemList.add( new Leaf(xpath, value)); } else { //有子元素 for (Iterator it = elements.iterator(); it.hasNext();) { Element elem = (Element) it.next(); //递归遍历 getElementList(elem); } } } public String getListString(List<Leaf> elemList) { StringBuffer sb = new StringBuffer(); for (Iterator<Leaf> it = elemList.iterator(); it.hasNext();) { Leaf leaf = it.next(); sb.append(leaf.getXpath()).append( " = ").append(leaf.getValue()).append( "\n"); } return sb.toString(); } } /** * xml节点数据结构 */ class Leaf { private String xpath; // private String value; public Leaf(String xpath, String value) { this.xpath = xpath; this.value = value; } public String getXpath() { return xpath; } public void setXpath(String xpath) { this.xpath = xpath; } public String getValue() { return value; } public void setValue(String value) { this.value = value; } }
运行结果:
-----------原xml内容------------
<? xml version ="1.0" encoding ="GBK" ?> < doc > < person > < name >某人 </ name > < adds > < add ID ="10002" > < BS >10002 </ BS > < note >西安市太白路 </ note > </ add > < add ID="" > < BS >10002 </ BS > < note >空ID节点啊 </ note > </ add > < add > < BS >10002 </ BS > < note >空ID节点啊 </ note > </ add > < add ID ="10001" > < BS xmlns ="10001" /> < note >西安市太白路2 </ note > </ add > </ adds > </ person > < other > < name ID ="HEHE" >ASDF </ name > </ other > </ doc > -----------解析结果------------ /doc/person/name = 某人 /doc/person/adds/add/BS = 10002 /doc/person/adds/add/note = 西安市太白路 /doc/person/adds/add/BS = 10002 /doc/person/adds/add/note = 空ID节点啊 /doc/person/adds/add/BS = 10002 /doc/person/adds/add/note = 空ID节点啊 /doc/person/adds/add/*[name()='BS'] = /doc/person/adds/add/note = 西安市太白路2 /doc/other/name = ASDF Process finished with exit code 0
可以发现,有很多xpath相同的值域。
本文出自 “
熔 岩” 博客,请务必保留此出处
http://lavasoft.blog.51cto.com/62575/71669
本文出自 51CTO.COM技术博客
|
转载于:https://blog.51cto.com/dorothyfeng/165863