demo4j解析xml

  1//先加入dom4j.jar包   2import java.util.HashMap;
  3import java.util.Iterator;
  4import java.util.Map;
  5  6import org.dom4j.Document;
  7import org.dom4j.DocumentException;
  8import org.dom4j.DocumentHelper;
  9import org.dom4j.Element;
 10 11/** 12* @Title: TestDom4j.java
 13* @Package
 14* @Description: 解析xml字符串
 15* @author 无处不在
 16* @date 2012-11-20 下午05:14:05
 17* @version V1.0
 18*/ 19publicclass TestDom4j {
 20 21publicvoid readStringXml(String xml) {
 22         Document doc = null;
 23try {
 24 25// 读取并解析XML文档
 26// SAXReader就是一个管道,用一个流的方式,把xml文件读出来
 27// 28// SAXReader reader = new SAXReader(); //User.hbm.xml表示你要解析的xml文档
 29// Document document = reader.read(new File("User.hbm.xml"));
 30// 下面的是通过解析xml字符串的 31             doc = DocumentHelper.parseText(xml); // 将字符串转为XML 32 33             Element rootElt = doc.getRootElement(); // 获取根节点 34             System.out.println("根节点:" + rootElt.getName()); // 拿到根节点的名称 35 36             Iterator iter = rootElt.elementIterator("head"); // 获取根节点下的子节点head
 37 38// 遍历head节点 39while (iter.hasNext()) {
 40 41                 Element recordEle = (Element) iter.next();
 42                 String title = recordEle.elementTextTrim("title"); // 拿到head节点下的子节点title值 43                 System.out.println("title:" + title);
 44 45                 Iterator iters = recordEle.elementIterator("script"); // 获取子节点head下的子节点script
 46 47// 遍历Header节点下的Response节点 48while (iters.hasNext()) {
 49 50                     Element itemEle = (Element) iters.next();
 51 52                     String username = itemEle.elementTextTrim("username"); // 拿到head下的子节点script下的字节点username的值 53                     String password = itemEle.elementTextTrim("password");
 54 55                     System.out.println("username:" + username);
 56                     System.out.println("password:" + password);
 57                }
 58            }
 59             Iterator iterss = rootElt.elementIterator("body"); ///获取根节点下的子节点body
 60// 遍历body节点 61while (iterss.hasNext()) {
 62 63                 Element recordEless = (Element) iterss.next();
 64                 String result = recordEless.elementTextTrim("result"); // 拿到body节点下的子节点result值 65                 System.out.println("result:" + result);
 66 67                 Iterator itersElIterator = recordEless.elementIterator("form"); // 获取子节点body下的子节点form
 68// 遍历Header节点下的Response节点 69while (itersElIterator.hasNext()) {
 70 71                     Element itemEle = (Element) itersElIterator.next();
 72 73                     String banlce = itemEle.elementTextTrim("banlce"); // 拿到body下的子节点form下的字节点banlce的值 74                     String subID = itemEle.elementTextTrim("subID");
 75 76                     System.out.println("banlce:" + banlce);
 77                     System.out.println("subID:" + subID);
 78                }
 79            }
 80         } catch (DocumentException e) {
 81            e.printStackTrace();
 82 83         } catch (Exception e) {
 84            e.printStackTrace();
 85 86        }
 87    }

/** 90     * @description 将xml字符串转换成map
 91     * @param xml
 92     * @return Map
 93*/ 94publicstatic Map readStringXmlOut(String xml) {
 95         Map map = new HashMap();
 96         Document doc = null;
 97try {
 98// 将字符串转为XML 99             doc = DocumentHelper.parseText(xml);
100// 获取根节点101             Element rootElt = doc.getRootElement();
102// 拿到根节点的名称103             System.out.println("根节点:" + rootElt.getName());
104105// 获取根节点下的子节点head106             Iterator iter = rootElt.elementIterator("head");
107// 遍历head节点108while (iter.hasNext()) {
109110                 Element recordEle = (Element) iter.next();
111// 拿到head节点下的子节点title值112                 String title = recordEle.elementTextTrim("title");
113                 System.out.println("title:" + title);
114                 map.put("title", title);
115// 获取子节点head下的子节点script116                 Iterator iters = recordEle.elementIterator("script");
117// 遍历Header节点下的Response节点118while (iters.hasNext()) {
119                     Element itemEle = (Element) iters.next();
120// 拿到head下的子节点script下的字节点username的值121                     String username = itemEle.elementTextTrim("username");
122                     String password = itemEle.elementTextTrim("password");
123124                     System.out.println("username:" + username);
125                     System.out.println("password:" + password);
126                     map.put("username", username);
127                     map.put("password", password);
128                }
129            }
130131//获取根节点下的子节点body132             Iterator iterss = rootElt.elementIterator("body");
133// 遍历body节点134while (iterss.hasNext()) {
135                 Element recordEless = (Element) iterss.next();
136// 拿到body节点下的子节点result值137                 String result = recordEless.elementTextTrim("result");
138                 System.out.println("result:" + result);
139// 获取子节点body下的子节点form140                 Iterator itersElIterator = recordEless.elementIterator("form");
141// 遍历Header节点下的Response节点142while (itersElIterator.hasNext()) {
143                     Element itemEle = (Element) itersElIterator.next();
144// 拿到body下的子节点form下的字节点banlce的值145                     String banlce = itemEle.elementTextTrim("banlce");
146                     String subID = itemEle.elementTextTrim("subID");
147148                     System.out.println("banlce:" + banlce);
149                     System.out.println("subID:" + subID);
150                     map.put("result", result);
151                     map.put("banlce", banlce);
152                     map.put("subID", subID);
153                }
154            }
155         } catch (DocumentException e) {
156            e.printStackTrace();
157         } catch (Exception e) {
158            e.printStackTrace();
159        }
160return map;
161    }
162
publicstaticvoid main(String[] args) {
164165// 下面是需要解析的xml字符串例子166         String xmlString = "<html>" + "<head>" + "<title>dom4j解析一个例子</title>"
167                 + "<script>" + "<username>yangrong</username>"
168                 + "<password>123456</password>" + "</script>" + "</head>"
169                 + "<body>" + "<result>0</result>" + "<form>"
170                 + "<banlce>1000</banlce>" + "<subID>36242519880716</subID>"
171                 + "</form>" + "</body>" + "</html>";
172173/*174         * Test2 test = new Test2(); test.readStringXml(xmlString);
175*/176         Map map = readStringXmlOut(xmlString);
177         Iterator iters = map.keySet().iterator();
178while (iters.hasNext()) {
179             String key = iters.next().toString(); // 拿到键180             String val = map.get(key).toString(); // 拿到值181             System.out.println(key + "=" + val);
182        }
183    }
184185 }

				
时间: 2024-10-10 07:17:14

demo4j解析xml的相关文章

【dom4j】解析xml为map

dom4j解析xml文件 <?xml version="1.0" encoding="utf-8"?> <workflows> <queryRequest> <branchId>88037062</branchId> <merSysId>00000317</merSysId> <queryNo>948983692</queryNo> <billType&

四种生成和解析XML文档的方法详解

众所周知,现在解析XML的方法越来越多,但主流的方法也就四种,即:DOM.SAX.JDOM和DOM4J 一.介绍及优缺点分析 1. DOM(Document Object Model) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的. [优点]      ①允许应用

DOM解析XML

DOM的文档驱动 处理DOM的时候,我们需要读入整个的XML文档,然后在内存中创建DOM树,生成 DOM树上的每个Node对象 优点是:可以对XML文档进行增删改查的复杂操作,可以随时按照节点间的关系访问数据 缺点: 受内存容量限制,不能处理大的文档,由于没有索引机制,处理效率较低 DOM(文档对象模型),为XML文档的解析定义了一组接口,解析器读入整个文档,然后构造一个驻留内存的树结构,然后代码就可以使用DOM接口来 操组整个树结构,其他点如下: 优点:整个文档树都在内存当中,便于操作:支持删

SAX解析XML

SAX 事件处理(事件驱动),不需要载入整个文档,流机制读取,分析XML文档 startDocument startElement character endElement endDocument 当sax扫描到文档时就调用startDocument函数,sax扫描到文档结束符时就调用endDocument函数,也就是说当sax扫描到哪个节点时就会调用相应的函数,同时还会携带节点的属性值. 当它扫描到节点内容值时就会调用character函数 Sax主要是用来对xml文件遍历,解析,不提供修改.

DOM的概念和简单应用:使用DOM解析XML数据

概念:DOM是Document Object Model的简称,即文档数据模型. Oracle公司提供了JAXP(Java API for XML Processing)来解析XML.JAXP会把XML文档转换成一个DOM树,JAXP的三个包都在JDK中. org.w3c.dom;W3C推荐的解析文档的接口 org.xml.sax;使用SAX解析XML文档的接口 javax.xml.parsers;解析器工厂工具 一.使用DOM解析XML文档的步骤 1.创建解析器工厂对象,即DocumentBu

Python数据清理之解析XML文件

解析XML 使用Beautiful Soup

[C#]记一次解析XML转对象的笔记

项目中调用第三方API,返回格式是XML字符串,需要将XML反序列化为对象,格式如下: 1 <?xml version="1.0"?> 2 <Response xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" totalCount="123" resultCode

XML引入,DOM 方式解析XML 原理,SAX 方式解析XML

XML 简介 Xml(eXtensible Markup Language) 即可扩展标记语言.提供了一套跨平台.跨网络.跨程序的语言的数据描述方式,使用XML 可以方便地实现数据交换.系统配置.内容管理等常见功能. 元素VS 节点 节点包括元素节点.属性节点.文本节点:元素一定是节点,但是节点不一定是元素: <?xml version="1.0" encoding="UTF-8"?> <emp> <empName empNo=&quo

【收藏用】--切勿转载JAVA 使用Dom4j 解析XML

原帖地址 : http://blog.csdn.NET/yyywyr/article/details/38359049 解析XML的方式有很多,本文介绍使用dom4j解析xml. 1.环境准备 (1)下载dom4j-1.6.1.jar (2)下载junit-4.10.jar 2.温馨提示 解析XML过程是通过获取Document对象,然后继续获取各个节点以及属性等操作,因此获取Document对象是第一步,大体说来,有三种方式: (1)自己创建Document对象   Document docu