dom4j創(chuàng)建和解析xml文檔的實現(xiàn)方法
DOM4J解析
特征:
1、JDOM的一種智能分支,它合并了許多超出基本XML文檔表示的功能。
2、它使用接口和抽象基本類方法。
3、具有性能優(yōu)異、靈活性好、功能強大和極端易用的特點。
4、是一個開放源碼的文件
jar包:dom4j-1.6.1.jar
創(chuàng)建 book.xml:
package com.example.xml.dom4j; import java.io.FileWriter; import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; import org.dom4j.io.OutputFormat; import org.dom4j.io.XMLWriter; /** * dom4j創(chuàng)建xml文檔示例 * */ public class Dom4JTest4 { public static void main(String[] args) throws Exception { // 第二種方式:創(chuàng)建文檔并設置文檔的根元素節(jié)點 Element root2 = DocumentHelper.createElement("bookstore"); Document document2 = DocumentHelper.createDocument(root2); // 添加一級子節(jié)點:add之后就返回這個元素 Element book1 = root2.addElement("book"); book1.addAttribute("id", "1"); book1.addAttribute("name", "第一本書"); // 添加二級子節(jié)點 book1.addElement("name").setText("遇見未知的自己"); book1.addElement("author").setText("張德芬"); book1.addElement("year").setText("2014"); book1.addElement("price").setText("109"); // 添加一級子節(jié)點 Element book2 = root2.addElement("book"); book2.addAttribute("id", "2"); book2.addAttribute("name", "第二本書"); // 添加二級子節(jié)點 book2.addElement("name").setText("雙城記"); book2.addElement("author").setText("狄更斯"); book2.addElement("year").setText("2007"); book2.addElement("price").setText("29"); // 設置縮進為4個空格,并且另起一行為true OutputFormat format = new OutputFormat(" ", true); // 另一種輸出方式,記得要調用flush()方法,否則輸出的文件中顯示空白 XMLWriter xmlWriter3 = new XMLWriter(new FileWriter("book.xml"),format); xmlWriter3.write(document2); xmlWriter3.flush(); // close()方法也可以 } }
運行結果:
解析 book.xml:
package com.example.xml.dom4j; import java.io.File; import java.util.Iterator; import java.util.List; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; /** * dom4j解析xml文檔示例 * */ public class Dom4JTest3 { public static void main(String[] args) { // 解析books.xml文件 // 創(chuàng)建SAXReader的對象reader SAXReader reader = new SAXReader(); try { // 通過reader對象的read方法加載books.xml文件,獲取docuemnt對象。 Document document = reader.read(new File("book.xml")); // 通過document對象獲取根節(jié)點bookstore Element bookStore = document.getRootElement(); System.out.println("根節(jié)點名:"+bookStore.getName()); // 通過element對象的elementIterator方法獲取迭代器 Iterator it = bookStore.elementIterator(); // 遍歷迭代器,獲取根節(jié)點中的信息(書籍) while (it.hasNext()) { System.out.println("=====開始遍歷子節(jié)點====="); Element book = (Element) it.next(); System.out.println("子節(jié)點名:"+book.getName()); // 獲取book的屬性名以及 屬性值 List<Attribute> bookAttrs = book.attributes(); for (Attribute attr : bookAttrs) { System.out.println("屬性名:" + attr.getName() + "--屬性值:" + attr.getValue()); } Iterator itt = book.elementIterator(); while (itt.hasNext()) { Element bookChild = (Element) itt.next(); System.out.println("節(jié)點名:" + bookChild.getName() + "--節(jié)點值:" + bookChild.getStringValue()); } System.out.println("=====結束遍歷該節(jié)點====="); } } catch (DocumentException e) { e.printStackTrace(); } } }
運行結果:
以上這篇dom4j創(chuàng)建和解析xml文檔的實現(xiàn)方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Spring數(shù)據(jù)庫連接池實現(xiàn)原理深入刨析
開發(fā)web項目,我們肯定會和數(shù)據(jù)庫打交道,因此就會涉及到數(shù)據(jù)庫鏈接的問題。在以前我們開發(fā)傳統(tǒng)的SSM結構的項目時進行數(shù)據(jù)庫鏈接都是通過JDBC進行數(shù)據(jù)鏈接,我們每和數(shù)據(jù)庫打一次交道都需要先獲取一次鏈接,操作完后再關閉鏈接,這樣子效率很低,因此就出現(xiàn)了連接池2022-11-11SpringBoot 2.0 整合sharding-jdbc中間件實現(xiàn)數(shù)據(jù)分庫分表
這篇文章主要介紹了SpringBoot 2.0 整合sharding-jdbc中間件,實現(xiàn)數(shù)據(jù)分庫分表,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-06-06Java內存模型與JVM運行時數(shù)據(jù)區(qū)的區(qū)別詳解
這篇文章主要介紹了Java內存模型與JVM運行時數(shù)據(jù)區(qū)的區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-10-10Spring Gateway自定義請求參數(shù)封裝的實現(xiàn)示例
這篇文章主要介紹了Spring Gateway自定義請求參數(shù)封裝的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-09-09