当前位置:首页 > 开发 > 编程语言 > XML > 正文

DOM解析XML字符串

发表于: 2009-08-24   作者:chicony   来源:转载   浏览次数:
摘要: 建好项目后导入dom4j-1.6.1.jar UtilXml.java package demo; import java.util.Iterator; import java.util.List; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Docum
建好项目后导入dom4j-1.6.1.jar
UtilXml.java
package demo;

import java.util.Iterator;
import java.util.List;

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

public class UtilXml {

	public static void main(String[] args) {

		String v_strXML = "<scheme><normal><time><start>08:30</start><end>12:00</end></time><time><start>13:30</start><end>17:30</end></time></normal><weekend><saturday><rest>1</rest></saturday><sunday><rest>1</rest></sunday></weekend><special><workday><date>2009-02-27</date></workday><holiday><date>2009-04-22</date></holiday><holiday><date>2009-04-26</date></holiday><workday><date>2009-04-28</date><time><start>10:00</start><end>12:00</end></time></workday><holiday><date>2009-04-29</date></holiday><workday><date>2009-04-30</date><time><start>10:30</start><end>17:00</end></time></workday></special></scheme>";

		Document doc = null;
		try {
			doc = DocumentHelper.parseText(v_strXML);
		} catch (DocumentException e2) {
			// TODO 自动生成 catch 块
			e2.printStackTrace();
		}
		Element root = doc.getRootElement();// 指向根节点

		// normal解析
		Element normal = root.element("normal");
		try {
			List lstTime = normal.elements("time");// 所有的Item节点
			for (int i = 0; i < lstTime.size(); i++) {
				Element etime = (Element) lstTime.get(i);
				Element start = etime.element("start");
				Element end = etime.element("end");
				System.out
						.println("start.getTextTrim()=" + start.getTextTrim());
				System.out.println("end.getTextTrim()=" + end.getTextTrim());
			}
			// Iterator Itr = lstTime.iterator();
			// while (Itr.hasNext()) {
			// Element etime = (Element) Itr.next();// 一个Item节点
			// Element start = etime.element("start");
			// Element end = etime.element("end");
			// System.out.println(start.getTextTrim());
			// System.out.println(end.getTextTrim());
			// }
		} catch (Exception e) {
			e.printStackTrace();
		}

		// weekend解析
		Element weekend = root.element("weekend");
		try {
			// 周6
			List lstSaturday = weekend.elements("saturday");// 所有的Item节点
			Iterator Itr1 = lstSaturday.iterator();
			while (Itr1.hasNext()) {
				Element eSaturday = (Element) Itr1.next();// 一个Item节点
				Element rest = eSaturday.element("rest");
				System.out.println("周六休息" + rest.getTextTrim());
			}

			// 周日
			List lstSunday = weekend.elements("sunday");// 所有的Item节点
			Iterator Itr2 = lstSunday.iterator();
			while (Itr2.hasNext()) {
				Element eSunday = (Element) Itr2.next();// 一个Item节点
				Element rest = eSunday.element("rest");
				System.out.println("周日休息" + rest.getTextTrim());
			}
		} catch (Exception e) {
			e.printStackTrace();
		}

		// special解析
		Element special = root.element("special");
		try {
			// 特殊工作日workday
			List lstWorkday = special.elements("workday");// 所有的Item节点
			Iterator Itr1 = lstWorkday.iterator();
			while (Itr1.hasNext()) {
				Element eWorkday = (Element) Itr1.next();// 一个Item节点
				Element date = eWorkday.element("date");
				System.out.println("特殊工作日===" + date.getText());
				List time = eWorkday.elements("time");
				Iterator Itr2 = time.iterator();
				while (Itr2.hasNext()) {
					Element etime = (Element) Itr2.next();
					Element start = etime.element("start");
					Element end = etime.element("end");
					System.out.println("特殊开始时间" + start.getTextTrim());
					System.out.println("特殊结束时间" + end.getTextTrim());
				}
			}

			// 节假日holiday
			List lstHoliday = special.elements("holiday");// 所有的Item节点
			Iterator Itr3 = lstHoliday.iterator();
			while (Itr3.hasNext()) {
				Element eHoliday = (Element) Itr3.next();// 一个Item节点
				Element date = eHoliday.element("date");
				System.out.println("节假日===" + date.getTextTrim());
			}

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



运行结果
start.getTextTrim()=08:30
end.getTextTrim()=12:00
start.getTextTrim()=13:30
end.getTextTrim()=17:30
周六休息1
周日休息1
特殊工作日===2009-02-27
特殊工作日===2009-04-28
特殊开始时间10:00
特殊结束时间12:00
特殊工作日===2009-04-30
特殊开始时间10:30
特殊结束时间17:00
节假日===2009-04-22
节假日===2009-04-26
节假日===2009-04-29

DOM解析XML字符串

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
Dom解析是将xml文件全部载入,组装成一颗dom树,然后通过节点以及节点之间的关系来解析xml文件,下
XML文档的概述 : 可扩展标记语言(eXtensibleMarkupLanguage,简称:XML: 前身是SGML(TheStandardGe
XML文档的概述 : 可扩展标记语言(eXtensibleMarkupLanguage,简称:XML: 前身是SGML(TheStandardGe
dom解析xml,会一次性读入xml文件,会把文件中的所有元素,解析成一个个Node对象节点。dom解析是基于
XML进行Dom解析: 一、XML进行Dom解析: XML:可拓展的标记语言,主要用来存储数据. Dom解析:在内存建
xml解析---DOM 工程结构图: [img] [/img] 效果图: [img] [/img] 一、stu.xml <?xml version="1.
XML进行Dom解析: 一、XML进行Dom解析: XML:可拓展的标记语言,主要用来存储数据. Dom解析:在内存建
DOM特点 1. 以树型结构访问XML文档。 2. 一棵DOM树包含全部元素节点和文本节点。 3. 可以前后遍历树
XML进行Dom解析: 一、XML进行Dom解析: XML:可拓展的标记语言,主要用来存储数据. Dom解析:在内存建
  在上一篇随笔中分析了xml以及它的两种验证方式。我们有了xml,但是里面的内容要怎么才能得到呢
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号