DOM解析XML字符串

建好项目后导入dom4j-1.6.1.jar

需要解析的xml文件:


解析代码:

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

下面介绍一下dom4j中常用API:

使用 DocumentHelper 类创建一个文档实例。 DocumentHelper 是生成 XML 文档节点的 dom4j API 工厂类。 Document document = DocumentHelper.createDocument(); 使用 addElement() 方法创建根元素 catalogaddElement() 用于向 XML 文档中增加元素。
Element catalogElement = document.addElement("catalog"); 在 catalog 元素中使用 addComment() 方法添加注释“An XML catalog”。 catalogElement.addComment("An XML catalog"); 在 catalog 元素中使用 addProcessingInstruction() 方法增加一个处理指令。 catalogElement.addProcessingInstruction("target","text"); 在 catalog 元素中使用 addElement() 方法增加 journal 元素。 Element journalElement = catalogElement.addElement("journal"); 使用 addAttribute() 方法向 journal 元素添加 title publisher 属性。
journalElement.addAttribute("title", "XML Zone"); journalElement.addAttribute("publisher", "developerWorks");










评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值