目标:使用JOM4j遍历所有的元素节点,并且取出来其中的值,结果打印到控制台。 源代码如下:本程序依赖DOM4j包。
|
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import java.util.*;
/**
* Created by IntelliJ IDEA.
*
User: leizhimin
*
Date: 2008-4-14 14:02:12
*
Note: Java递归遍历XML所有元素
*/
public class XmlTest {
// private static Map
xmlmap = new HashMap
(); //存储xml元素信息的容器 private static List
elemList = new ArrayList
(); //要测试的xml对象 private static String srcXml = "
\n" + "
\n" + "
\n" + "
某人\n" + "
\n" + "
\n" + "
10002\n" + "
西安市太白路\n" + " \n" + "
\n" + "
10002\n" + "
空ID节点啊\n" + " \n" + "
\n" + "
10002\n" + "
空ID节点啊\n" + " \n" + "\t\t\t
\n" + "\t\t\t\t
\n" + "
西安市太白路2\n" + " \n" + "\t\t\n" + " \n" + "
\n" + "
ASDF\n" + " \n" + ""; 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
elemList) { StringBuffer sb = new StringBuffer(); for (Iterator
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内容------------
|
某人
10002
西安市太白路
10002
空ID节点啊
10002
空ID节点啊
西安市太白路2
ASDF -----------解析结果------------ /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相同的值域。
【编辑推荐】
- 高手Java核心技术学习笔记
- 如何使用 JavaScript XSLT 处理 XML 文件
- JSP结合XML+XSLT将输出转换HTML
- Java通过JNI调用C语言的方法
- JAVA环境变量的设置
分享题目:Dom4j递归遍历XML所有元素
标题来源:http://www.csdahua.cn/qtweb/news19/472269.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
广告
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源:
快上网