博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java dom4j 解析xml字符串的操作实例
阅读量:4125 次
发布时间:2019-05-25

本文共 6925 字,大约阅读时间需要 23 分钟。

package test;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;/**   * @Title: TestDom4j.java* @Package * @Description: 解析xml字符串* @author 无处不在* @date 2012-11-20 下午05:14:05* @version V1.0   */public class ParseDataUtil {  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"));          // 下面的是通过解析xml字符串的          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);              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 {          // 将字符串转为XML          doc = DocumentHelper.parseText(xml);           // 获取根节点          Element rootElt = doc.getRootElement();           // 拿到根节点的名称          System.out.println("根节点:" + rootElt.getName());           // 获取根节点下的子节点head          Iterator iter = rootElt.elementIterator("head");           // 遍历head节点          while (iter.hasNext()) {              Element recordEle = (Element) iter.next();              // 拿到head节点下的子节点title值              String title = recordEle.elementTextTrim("title");               System.out.println("title:" + title);              map.put("title", title);              // 获取子节点head下的子节点script              Iterator iters = recordEle.elementIterator("script");               // 遍历Header节点下的Response节点              while (iters.hasNext()) {                  Element itemEle = (Element) iters.next();                  // 拿到head下的子节点script下的字节点username的值                  String username = itemEle.elementTextTrim("username");                   String password = itemEle.elementTextTrim("password");                  System.out.println("username:" + username);                  System.out.println("password:" + password);                  map.put("username", username);                  map.put("password", password);              }          }          //获取根节点下的子节点body          Iterator iterss = rootElt.elementIterator("body");           // 遍历body节点          while (iterss.hasNext()) {              Element recordEless = (Element) iterss.next();              // 拿到body节点下的子节点result值              String result = recordEless.elementTextTrim("result");               System.out.println("result:" + result);              // 获取子节点body下的子节点form              Iterator itersElIterator = recordEless.elementIterator("form");               // 遍历Header节点下的Response节点              while (itersElIterator.hasNext()) {                  Element itemEle = (Element) itersElIterator.next();                  // 拿到body下的子节点form下的字节点banlce的值                  String banlce = itemEle.elementTextTrim("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 =   "" + 	  "" + 		  "dom4j解析一个例子"+ 		  "" + 	  ""+ 	  "" + 		  "
0
" + "
" + "
1000
" + "
36242519880716
"+ "
" + "" + ""; /* * 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); } }}

转载地址:http://melpi.baihongyu.com/

你可能感兴趣的文章
hdu 3787 hdoj 3787
查看>>
hdu 3790 hdoj 3790
查看>>
hdu 3789 hdoj 3789
查看>>
hdu 3788 hdoj 3788
查看>>
zju 1003 zoj 1003
查看>>
zju 1004 zoj 1004
查看>>
zju 1005 zoj 1005
查看>>
zju 1006 zoj 1006
查看>>
【虚拟机】虚拟化架构与系统部署(Windows系统安装)
查看>>
字节跳动安卓开发实习生面试分享
查看>>
好书分享之——《能力陷进》
查看>>
阅读笔记《c++ primer》
查看>>
阅读笔记《C++标准程序库》
查看>>
基于mirror driver的windows屏幕录像
查看>>
C语言8
查看>>
Qt实现简单延时
查看>>
qml有关矩形说明
查看>>
在qt中使用QSplitter设置初始比例setStretchFactor失效的解决方法
查看>>
repeater的使用
查看>>
qt msvc编译中文乱码解决
查看>>