Java dom4j創(chuàng)建解析xml文檔過程解析
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)建文檔并設(shè)置文檔的根元素節(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'); // 設(shè)置縮進為4個空格,并且另起一行為true OutputFormat format = new OutputFormat(' ', true); // 另一種輸出方式,記得要調(diào)用flush()方法,否則輸出的文件中顯示空白 XMLWriter xmlWriter3 = new XMLWriter(new FileWriter('book.xml'),format); xmlWriter3.write(document2); xmlWriter3.flush(); // close()方法也可以 }}
運行結(jié)果:
解析 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é)束遍歷該節(jié)點====='); } } catch (DocumentException e) { e.printStackTrace(); } }}
運行結(jié)果:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. python中scrapy處理項目數(shù)據(jù)的實例分析2. js抽獎轉(zhuǎn)盤實現(xiàn)方法分析3. IntelliJ IDEA導(dǎo)入jar包的方法4. Python requests庫參數(shù)提交的注意事項總結(jié)5. 教你在 IntelliJ IDEA 中使用 VIM插件的詳細(xì)教程6. SpringBoot參數(shù)校驗與國際化使用教程7. iOS實現(xiàn)點贊動畫特效8. python操作mysql、excel、pdf的示例9. 通過Python pyecharts輸出保存圖片代碼實例10. vue-electron中修改表格內(nèi)容并修改樣式
