`
zhoulianglg
  • 浏览: 19041 次
  • 性别: Icon_minigender_1
  • 来自: 南京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

dom4j解析xml

 
阅读更多
//先加入dom4j.jar包
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;

/**
* @description 解析xml字符串
*
@author 无处不在
* @Time 上午11:01:31
*/
public class Test {

public void readStringXml(String xml) {
Document doc
= null;
try {

// 读取并解析XML文档
//
SAXReader就是一个管道,用一个流的方式,把xml文件读出来

SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档
Document document = reader.read(new File("User.hbm.xml"));

Element rootElt
= doc.getRootElement(); // 获取根节点
System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称

Iterator iter
= rootElt.elementIterator("head"); // 获取根节点下的子节点head

// 遍历head节点
while (iter.hasNext()) {

Element recordEle
= (Element) iter.next();
String title
= recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值
System.out.println("title:" + title);

Iterator iters
= recordEle.elementIterator("script"); // 获取子节点head下的子节点script

// 遍历Header节点下的Response节点
while (iters.hasNext()) {

Element itemEle
= (Element) iters.next();

String username
= itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值
String password = itemEle.elementTextTrim("password");

System.out.println(
"username:" + username);
System.out.println(
"password:" + password);
}
}
Iterator iterss
= rootElt.elementIterator("body"); ///获取根节点下的子节点body
// 遍历body节点
while (iterss.hasNext()) {

Element recordEless
= (Element) iterss.next();
String result
= recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值
System.out.println("result:" + result);

Iterator itersElIterator
= recordEless.elementIterator("form"); // 获取子节点body下的子节点form
// 遍历Header节点下的Response节点
while (itersElIterator.hasNext()) {

Element itemEle
= (Element) itersElIterator.next();

String banlce
= itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值
String subID = itemEle.elementTextTrim("subID");

System.out.println(
"banlce:" + banlce);
System.out.println(
"subID:" + subID);
}
}
}
catch (DocumentException e) {
e.printStackTrace();

}
catch (Exception e) {
e.printStackTrace();

}
}

/**
* @description 将xml字符串转换成map
*
@param xml
*
@return Map
*/
public static Map readStringXmlOut(String xml) {
Map map
= new HashMap();
Document doc
= null;
try {
doc
= DocumentHelper.parseText(xml); // 将字符串转为XML
Element rootElt = doc.getRootElement(); // 获取根节点
System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称

Iterator iter
= rootElt.elementIterator("head"); // 获取根节点下的子节点head
// 遍历head节点
while (iter.hasNext()) {

Element recordEle
= (Element) iter.next();
String title
= recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值
System.out.println("title:" + title);
map.put(
"title", title);

Iterator iters
= recordEle.elementIterator("script"); // 获取子节点head下的子节点script

// 遍历Header节点下的Response节点
while (iters.hasNext()) {

Element itemEle
= (Element) iters.next();

String username
= itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值
String password = itemEle.elementTextTrim("password");

System.out.println(
"username:" + username);
System.out.println(
"password:" + password);
map.put(
"username", username);
map.put(
"password", password);

}
}

Iterator iterss
= rootElt.elementIterator("body"); ///获取根节点下的子节点body
// 遍历body节点
while (iterss.hasNext()) {
Element recordEless
= (Element) iterss.next();
String result
= recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值
System.out.println("result:" + result);

Iterator itersElIterator
= recordEless.elementIterator("form"); // 获取子节点body下的子节点form
// 遍历Header节点下的Response节点
while (itersElIterator.hasNext()) {

Element itemEle
= (Element) itersElIterator.next();

String banlce
= itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值
String subID = itemEle.elementTextTrim("subID");

System.out.println(
"banlce:" + banlce);
System.out.println(
"subID:" + subID);
map.put(
"result", result);
map.put(
"banlce", banlce);
map.put(
"subID", subID);
}
}
}
catch (DocumentException e) {
e.printStackTrace();
}
catch (Exception e) {
e.printStackTrace();
}
return map;
}

public static void main(String[] args) {

// 下面是需要解析的xml字符串例子
String xmlString = "<html>" + "<head>" + "<title>dom4j解析一个例子</title>"
+ "<script>" + "<username>yangrong</username>"
+ "<password>123456</password>" + "</script>" + "</head>"
+ "<body>" + "<result>0</result>" + "<form>"
+ "<banlce>1000</banlce>" + "<subID>36242519880716</subID>"
+ "</form>" + "</body>" + "</html>";

/*
* Test2 test = new Test2(); test.readStringXml(xmlString);
*/
Map map
= readStringXmlOut(xmlString);
Iterator iters
= map.keySet().iterator();
while (iters.hasNext()) {
String key
= iters.next().toString(); // 拿到键
String val = map.get(key).toString(); // 拿到值
System.out.println(key + "=" + val);
}
}

}
分享到:
评论

相关推荐

    dom4j解析xml详解

    ### DOM4J解析XML详解 #### 一、DOM4J简介与特性 DOM4J是一个由dom4j.org开发的开源XML解析包,专为Java平台设计,它不仅支持DOM、SAX和JAXP标准,还巧妙地融入了Java集合框架,使其成为Java开发者在处理XML数据时...

    使用 dom4j 解析 XML

    使用 dom4j 解析 XML dom4j 解析 XML dom4j解析xml

    DOM4J 解析XML

    **DOM4J解析XML** DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效且功能丰富的API,使得XML的读取、创建、修改和查询变得简单易行。DOM4J的主要特点包括对XPath的支持、事件驱动的解析、以及与...

    java dom4j解析xml

    Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...

    dom4j解析xml文件(增删改查)

    在“dom4j解析xml文件(增删改查)”这个主题中,我们将深入探讨如何使用DOM4J来实现XML文档的四种基本操作:增加元素、删除元素、更新元素内容以及查询元素。 首先,让我们了解DOM4J的基本用法。在解析XML文件时,...

    dom4j解析xml实例

    **DOM4J解析XML实例详解** 在Java编程中,处理XML文档是一项常见的任务。DOM4J是一个非常流行的、强大的Java XML API,它提供了灵活且高效的方式来解析、创建、修改XML文档。本文将深入探讨如何使用DOM4J进行XML...

    dom4j 解析xml实例

    在这个实例中,我们将深入探讨如何使用DOM4J解析XML文件,并通过`Dom4jTest1.java`这个示例程序来理解其工作原理。 首先,我们需要了解XML(Extensible Markup Language)是一种标记语言,常用于存储和传输数据。...

    dom4j解析XML

    本人自己研究的解析方法,主要用dom4j解析XML文件,进而获取里面的信息

    dom4j解析xml,利用反射机制

    通过这种方式,我们可以利用DOM4J解析XML文件,同时借助Java反射机制将解析结果动态地映射到自定义的Java类中。这在处理XML数据时提供了很大的灵活性,尤其在需要将XML数据与业务对象关联时,反射机制显得尤为重要。

    dom4j解析xml文件代码示例

    在本示例中,我们将深入探讨如何使用DOM4J解析XML文件,以`CacheInit.java`作为我们的核心代码示例,并参考`emailTemplateConfig.xml`作为实际操作的对象。 首先,让我们了解XML(eXtensible Markup Language)。...

    java dom4j 解析xml的例子,可用

    1. **DOM4J解析XML**:DOM4J通过创建一个可操作的树形结构来表示XML文档,这棵树称为文档对象模型。解析XML时,DOM4J首先读取XML文件并构建一个节点结构,然后你可以通过API遍历和修改这个结构。例如,你可以通过...

    使用dom4j解析XML

    【使用dom4j解析XML】 dom4j是一个强大的开源XML框架,它提供了处理XML文档的各种功能,包括解析、创建、修改等。相比W3C DOM API,dom4j的优势在于其内置的XPath支持,允许更方便地定位和操作XML文档中的节点。 *...

    dom4j 解析写入xml

    1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件

    dom4j解析XML所需要的jar包

    为了在Java项目中使用DOM4J解析XML,你需要将这两个jar文件(dom4j-1.6.1和jaxen-1.1-beta-7.jar)添加到你的类路径(classpath)中。这可以通过在IDE中配置构建路径,或者在命令行中指定 `-cp` 参数来完成。一旦...

    dom4j解析xml,连接oracle数据库

    在本实例中,我们将深入探讨如何使用DOM4J解析XML,并利用这些数据连接Oracle数据库进行数据操作。 首先,让我们了解DOM4J的基本用法。DOM4J的主要类包括`Document`、`Element`、`Attribute`和`Namespace`。`...

    dom4j解析XML所需jar包

    2. **XML解析**:DOM4J支持多种解析方式,包括SAX(Simple API for XML)和DOM。SAX是基于事件的解析,适用于处理大文件;DOM则将整个XML文档加载到内存,适合小规模或内存允许的情况。DOM4J还提供了StAX(Streaming...

    dom4j解析xml字符串实例

    dom4j解析xml字符串实例

Global site tag (gtag.js) - Google Analytics