`

简单地解析dom字符串(dom4j)

阅读更多
package October;

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 DOMTest {

	public static void main(String[] args) {

		String v_strXML = "<?xml version=\"1.0\" encoding=\"UTF-8\"?><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) {
			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());
			}
		} 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();
		}
	}
}

 以上dom的字符串如下:

<?xml version="1.0" encoding="UTF-8"?>
<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>

 

本例子需要导入dom4j的包,本实例为dom4j-1.6.1.jar。 

运行结果如下:

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

 

以上内容摘自互联网。 感谢原作者,原谅我忘记了从哪里载的。

分享到:
评论

相关推荐

    dom4j解析xml字符串实例

    dom4j解析xml字符串实例

    dom4j解析xml字符串

    // 下面的是通过解析xml字符串的 doc = DocumentHelper.parseText(xml); // 将字符串转为XML Element rootElt = doc.getRootElement(); // 获取根节点 System.out.println("根节点:"+ rootElt.getName()); // ...

    dom4j解析字符串

    dom4j解析字符串 dom4j是Java语言中的一个开源API,用于解析XML文件和字符串。它具有性能优异、功能强大和极端易用使用的特点,只要懂得DOM基本概念,就可以通过dom4j的API文档来解析XML。 dom4j的优点: * 高...

    利用DOM4J解析SOAP的简单示例

    本篇文章将深入探讨如何利用DOM4J解析SOAP消息中的元素,以便在实际项目中进行有效的数据提取和操作。 首先,理解SOAP消息的结构至关重要。一个典型的SOAP消息如下所示: ```xml &lt;!-- Header元素中的内容 --&gt; ...

    使用dom4j将xml字符串转换成Bean对象

    当我们需要将XML字符串解析并映射到Java Bean对象时,dom4j是一个常用的库。本篇文章将详细探讨如何使用dom4j库实现这个过程。 首先,dom4j是一个强大的Java XML API,它提供了丰富的功能,如读取、写入、修改和...

    DOM4J jar包 xml解析 所有的dom4j-1.6.1 dom4j-2.0.2 dom4j-2.1.1包 导入直接使用

    4. **XPath支持**:DOM4J实现了XPath表达式,允许通过简单的字符串查询XML文档中的任意节点,大大提高了代码的可读性和效率。 5. **XML Schema支持**:DOM4J能够处理XML Schema,进行XML文档的验证,确保数据的正确...

    DOM4J 读取xml字符串

    **DOM4J 读取XML字符串** DOM4J 是一个非常强大的 Java XML API,它提供了丰富的功能,使得处理 XML 文件变得更加简单。DOM4J 的设计理念是简洁、灵活且高性能,它支持 SAX 和 DOM 解析,并提供了面向对象的接口。...

    DOM、SAX、DOM4J、JDOM、StAX生成XML并返回XML字符串形式

    DOM4J支持XPath查询,可以更简单地定位和操作XML节点。此外,DOM4J也支持SAX解析,结合了DOM的便利性和SAX的效率。在生成XML字符串时,DOM4J提供了简洁的API来构建和输出XML文档。 4. JDOM JDOM是另一个Java的XML...

    dom4j 解析写入xml

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

    xml字符串解析

    在Java中,我们可以使用DOM4J来解析XML字符串,以下是一个简单的步骤: 1. **导入DOM4J库**:确保项目中已经引入了DOM4J的依赖,如果没有,可以添加对应的Maven或Gradle依赖。 2. **读取XML字符串**:从文件、网络...

    dom4j dom4j1.6 dom4j最新版

    5. **转换和序列化**:DOM4J可以将XML文档转换为其他格式,如HTML或者DOM,也可以将XML对象序列化回字符串或文件。 6. **文档结构**:DOM4J的Document、Element、Attribute、Namespace等类提供了清晰的文档结构表示...

    通过dom4j解析xml字符串(示例代码)

    通过DOM4J解析XML字符串是Java开发中处理XML数据的常见方法。DOM4J是一个非常灵活的用于处理XML、HTML和XSLT的Java库,它提供了丰富的API来操作XML文档,包括创建、读取、修改和遍历XML文档。在本文中,我们将深入...

    dom4j-jar与dom4j解析xml文档介绍

    4. **XPath支持**:dom4j支持XPath表达式,允许开发者通过简洁的字符串路径来选取XML文档中的节点,大大提高了代码的可读性和效率。 5. **操作XML**:使用dom4j可以方便地添加、删除、修改XML元素和属性,以及遍历...

    PB解析XML字符串 把XML 变为数据窗口

    1. 加载XML字符串:首先,你需要使用PB的XML解析函数如`XMLTextToDOM`或`XMLTextToDOMEx`,将XML文本转换成DOM(Document Object Model)对象。DOM是XML文档的一种内存表示,可以方便地通过节点遍历和操作。 2. ...

    java解析XML dom4j dom4j-1.6.1.jar

    Java解析XML时,dom4j是一个非常流行的库,它提供了灵活且强大的API来处理XML文档。dom4j-1.6.1.jar是这个库的一个版本,发布于2005年,它支持XML的读取、写入、操作以及查询功能。在本文中,我们将深入探讨dom4j的...

    DOM4J解析XML

    1. **DOM解析方式**:DOM4J通过DOM接口来解析XML,将整个XML文档加载到内存中形成一个树形结构,称为DOM树。这样做的优点是可以方便地通过路径导航访问任何元素,缺点是如果XML文件过大,可能会消耗大量内存。 2. *...

    dom4j解析XML所需要的jar包

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

Global site tag (gtag.js) - Google Analytics