Java進階(二十七)使用Dom4j解析XML文件

      網友投稿 1668 2025-04-02

      使用Dom4j解析XML文件

      寫在前面的話

      由于論文實驗要求,需要實現操作XML文檔,為此想到了dom4j這個工具,使用之后深感受益。在此分享給大家,以此共勉。

      正文

      dom4j是一個Java的XML API,類似于jdom,用來讀寫XML文件的。dom4j是一個非常非常優秀的Java XML API,具有性能優異、功能強大和簡單易用等優點,同時它也是一個開放源代碼的軟件,可以在SourceForge上找到它。

      對主流的Java XML API進行的性能、功能和易用性的評測,dom4j無論在那個方面都是非常出色的。如今你可以看到越來越多的Java軟件都在使用dom4j來讀寫XML,例如Hibernate,包括sun公司自己的JAXM也用了Dom4j。

      使用Dom4j開發,需下載dom4j相應的jar文件

      1.官網下載:

      http://www.dom4j.org/dom4j-1.6.1/

      2.dom4j是sourceforge.net上的一個開源項目,因此可以到

      http://sourceforge.net/projects/dom4j

      下載其最新版。

      對于下載的zip文件進行解壓后的效果如下:

      打開dom4j-1.6.1的解壓文件

      在這里可以看到有docs幫助的文件夾,也有需要使用dom4j解析xml文件的dom4j-1.6.1.jar文件.我們只需要把dom4j-1.6.1.jar文件構建到我們開發的項目中就可以使用dom4j開發了.

      下面我以Myeclipse創建Java項目的構建方法為例說明.

      首先創建一個demo項目,在demo項目中創建一個lib文件,把dom4j-1.6.1.jar文件拷貝到lib中,然后右鍵dom4j-1.6.1jar文件

      點擊Add to Build Path即可構建到項目中去了.

      備注:如果進行的是web項目開發,我們只需要把它拷貝到web-inf/lib中去即可,會自動構建到web項目中.

      在項目開發的過程中可以參考docs文件夾的(幫助文檔),找到index.html打開,點擊Quick start可以通過幫助文檔進行學習 dom4j進行xml的解析.

      下面我對我認為api中重要的方法進行翻譯說明如下:

      一、DOM4j中,獲得Document對象的方式有三種

      1.讀取XML文件,獲得document對象

      SAXReader reader = new SAXReader();

      Document ??document = reader.read(new File("csdn.xml"));

      2.解析XML形式的文本,得到document對象.

      String text = "";

      Document document = DocumentHelper.parseText(text);

      3.主動創建document對象.

      Document document = DocumentHelper.createDocument();

      //創建根節點

      Element root = document.addElement("csdn");

      二、節點對象操作的方法

      1.獲取文檔的根節點.

      Element root = document.getRootElement();

      2.取得某個節點的子節點.

      Element element=node.element(“四大名著");

      3.取得節點的文字

      String text=node.getText();

      4.取得某節點下所有名為“csdn”的子節點,并進行遍歷.

      List nodes = rootElm.elements("csdn");

      for (Iterator it = nodes.iterator(); it.hasNext();) {

      Element elm = (Element) it.next();

      // do something

      }

      5.對某節點下的所有子節點進行遍歷.

      for(Iterator it=root.elementIterator();it.hasNext();){

      Element element = (Element) it.next();

      // do something

      }

      6.在某節點下添加子節點

      Element elm = newElm.addElement("朝代");

      7.設置節點文字.

      elm.setText("明朝");

      8.刪除某節點.

      //childElement是待刪除的節點,parentElement是其父節點

      parentElement.remove(childElment);

      9.添加一個CDATA節點.

      Element contentElm = infoElm.addElement("content");

      contentElm.addCDATA(“cdata區域”);

      三、節點對象的屬性方法操作

      1.取得某節點下的某屬性

      Element root=document.getRootElement();

      //屬性名name

      Attribute attribute=root.attribute("id");

      2.取得屬性的文字

      String text=attribute.getText();

      3.刪除某屬性

      Attribute attribute=root.attribute("size");

      Java進階(二十七)使用Dom4j解析XML文件

      root.remove(attribute);

      4.遍歷某節點的所有屬性

      Element root=document.getRootElement();

      for(Iterator it=root.attributeIterator();it.hasNext();){

      Attribute attribute = (Attribute) it.next();

      String text=attribute.getText();

      System.out.println(text);

      }

      5.設置某節點的屬性和文字.

      newMemberElm.addAttribute("name", "sitinspring");

      6.設置屬性的文字

      Attribute attribute=root.attribute("name");

      attribute.setText("csdn");

      四、將文檔寫入XML文件

      1.文檔中全為英文,不設置編碼,直接寫入的形式.

      XMLWriter writer = new XMLWriter(new FileWriter("ot.xml"));

      writer.write(document);

      writer.close();

      2.文檔中含有中文,設置編碼格式寫入的形式.

      OutputFormat format = OutputFormat.createPrettyPrint();

      // 創建文件輸出的時候,自動縮進的格式

      format.setEncoding("UTF-8");//設置編碼

      XMLWriter writer = new XMLWriter(newFileWriter("output.xml"),format);

      writer.write(document);

      writer.close();

      五、字符串與XML的轉換

      1.將字符串轉化為XML

      String text = " Java班";

      Document document = DocumentHelper.parseText(text);

      2.將文檔或節點的XML轉化為字符串.

      SAXReader reader = new SAXReader();

      Document document = reader.read(new File("csdn.xml"));

      Element root=document.getRootElement();

      String docXmlText=document.asXML();

      String rootXmlText=root.asXML();

      Element memberElm=root.element("csdn");

      String memberXmlText=memberElm.asXML();

      六、案例(解析sida.xml文件并對其進行curd的操作)

      1.sida.xml描述四大名著的操作

      文件內容如下

      <四大名著>

      <西游記 id="x001">

      <朝代>明朝

      <紅樓夢 id="x002">

      2.解析類測試操作

      package dom4j;

      import java.io.File;

      import java.io.FileOutputStream;

      import java.io.FileWriter;

      import java.io.OutputStreamWriter;

      import java.nio.charset.Charset;

      import java.nio.charset.CharsetEncoder;

      import java.util.Iterator;

      import java.util.List;

      import org.dom4j.Attribute;

      import org.dom4j.Document;

      import org.dom4j.Element;

      import org.dom4j.io.OutputFormat;

      import org.dom4j.io.SAXReader;

      import org.dom4j.io.XMLWriter;

      import org.junit.Test;

      public class Demo01 {

      @Test

      public void test() throws Exception {

      // 創建saxReader對象

      SAXReader reader = new SAXReader();

      // 通過read方法讀取一個文件 轉換成Document對象

      Document document = reader.read(new File("src/dom4j/sida.xml"));

      //獲取根節點元素對象

      Element node = document.getRootElement();

      //遍歷所有的元素節點

      listNodes(node);

      // 獲取四大名著元素節點中,子節點名稱為紅樓夢元素節點。

      Element element = node.element("紅樓夢");

      //獲取element的id屬性節點對象

      Attribute attr = element.attribute("id");

      //刪除屬性

      element.remove(attr);

      //添加新的屬性

      // 在紅樓夢元素節點中添加朝代元素的節點

      Element newElement = element.addElement("朝代");

      newElement.setText("清朝");

      //刪除元素節點

      boolean flag = element.remove(author);

      //返回true代碼刪除成功,否則失敗

      System.out.println(flag);

      //添加CDATA區域

      element.addCDATA("紅樓夢,是一部愛情小說.");

      // 寫入到一個新的文件中

      writer(document);

      }

      /**

      * 把document對象寫入新的文件

      *

      * @param document

      * @throws Exception

      */

      public void writer(Document document) throws Exception {

      // 緊湊的格式

      // OutputFormat format = OutputFormat.createCompactFormat();

      // 排版縮進的格式

      OutputFormat format = OutputFormat.createPrettyPrint();

      // 設置編碼

      format.setEncoding("UTF-8");

      // 創建XMLWriter對象,指定了寫出文件及編碼格式

      // XMLWriter writer = new XMLWriter(new FileWriter(new

      // File("src//a.xml")),format);

      XMLWriter writer = new XMLWriter(new OutputStreamWriter(

      new FileOutputStream(new File("src//a.xml")), "UTF-8"), format);

      // 寫入

      writer.write(document);

      // 立即寫入

      writer.flush();

      // 關閉操作

      writer.close();

      }

      /**

      * 遍歷當前節點元素下面的所有(元素的)子節點

      *

      * @param node

      */

      public void listNodes(Element node) {

      System.out.println("當前節點的名稱::" + node.getName());

      // 獲取當前節點的所有屬性節點

      List list = node.attributes();

      // 遍歷屬性節點

      for (Attribute attr : list) {

      System.out.println(attr.getText() + "-----" + attr.getName()

      + "---" + attr.getValue());

      }

      if (!(node.getTextTrim().equals(""))) {

      System.out.println("文本內容::::" + node.getText());

      }

      // 當前節點下面子節點迭代器

      Iterator it = node.elementIterator();

      // 遍歷

      while (it.hasNext()) {

      // 獲取某個子節點對象

      Element e = it.next();

      // 對子節點進行遍歷

      listNodes(e);

      }

      }

      /**

      * 介紹Element中的element方法和elements方法的使用

      *

      * @param node

      */

      public void elementMethod(Element node) {

      // 獲取node節點中,子節點的元素名稱為西游記的元素節點。

      Element e = node.element("西游記");

      System.out.println(e.getName() + "----" + author.getText());

      for (Element aut : authors) {

      System.out.println(aut.getText());

      }

      // 獲取西游記這個元素節點 所有元素的子節點。

      List elements = e.elements();

      for (Element el : elements) {

      System.out.println(el.getText());

      }

      }

      }

      自己適當注釋部分代碼觀察運行效果,反復練習,希望你對dom4j有進一步的了解.

      七、字符串與XML互轉換案例

      package dom4j;

      import java.io.File;

      import java.io.FileOutputStream;

      import java.io.OutputStreamWriter;

      import org.dom4j.Document;

      import org.dom4j.DocumentHelper;

      import org.dom4j.Element;

      import org.dom4j.io.OutputFormat;

      import org.dom4j.io.SAXReader;

      import org.dom4j.io.XMLWriter;

      import org.junit.Test;

      public class Demo02 {

      @Test

      public void test() throws Exception {

      // 創建saxreader對象

      SAXReader reader = new SAXReader();

      // 讀取一個文件,把這個文件轉換成Document對象

      Document document = reader.read(new File("src//c.xml"));

      // 獲取根元素

      Element root = document.getRootElement();

      // 把文檔轉換字符串

      String docXmlText = document.asXML();

      System.out.println(docXmlText);

      System.out.println("---------------------------");

      // csdn元素標簽根轉換的內容

      String rootXmlText = root.asXML();

      System.out.println(rootXmlText);

      System.out.println("---------------------------");

      // 獲取java元素標簽 內的內容

      Element e = root.element("java");

      System.out.println(e.asXML());

      }

      /**

      * 創建一個document對象 往document對象中添加節點元素 轉存為xml文件

      *

      * @throws Exception

      */

      public void test2() throws Exception {

      Document document = DocumentHelper.createDocument();// 創建根節點

      Element root = document.addElement("csdn");

      Element java = root.addElement("java");

      java.setText("java班");

      Element ios = root.addElement("ios");

      ios.setText("ios班");

      writer(document);

      }

      /**

      * 把一個文本字符串轉換Document對象

      *

      * @throws Exception

      */

      public void test1() throws Exception {

      String text = "Java班Net班";

      Document document = DocumentHelper.parseText(text);

      Element e = document.getRootElement();

      System.out.println(e.getName());

      writer(document);

      }

      /**

      * 把document對象寫入新的文件

      *

      * @param document

      * @throws Exception

      */

      public void writer(Document document) throws Exception {

      // 緊湊的格式

      // OutputFormat format = OutputFormat.createCompactFormat();

      // 排版縮進的格式

      OutputFormat format = OutputFormat.createPrettyPrint();

      // 設置編碼

      format.setEncoding("UTF-8");

      // 創建XMLWriter對象,指定了寫出文件及編碼格式

      // XMLWriter writer = new XMLWriter(new FileWriter(new

      // File("src//a.xml")),format);

      XMLWriter writer = new XMLWriter(new OutputStreamWriter(

      new FileOutputStream(new File("src//c.xml")), "UTF-8"), format);

      // 寫入

      writer.write(document);

      // 立即寫入

      writer.flush();

      // 關閉操作

      writer.close();

      }

      }

      美文美圖

      Java XML

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      上一篇:excel2019怎么刪除工作表列
      下一篇:在wps表格中怎么設置將圖片放大(wps表格添加圖片大縮小怎么辦)
      相關文章
      www国产亚洲精品久久久| 亚洲成人高清在线观看| 亚洲六月丁香六月婷婷色伊人| 亚洲午夜福利AV一区二区无码| 亚洲av成人一区二区三区在线观看 | 激情无码亚洲一区二区三区| 亚洲精品宾馆在线精品酒店| 亚洲第一成人在线| 亚洲人成在线中文字幕| 亚洲网红精品大秀在线观看 | 亚洲第一中文字幕| 亚洲第一极品精品无码久久| 国产亚洲精品观看91在线| 亚洲午夜未满十八勿入网站2| 亚洲无码在线播放| 亚洲精品无码MV在线观看| 国产V亚洲V天堂A无码| 国产亚洲精品一品区99热| 亚洲成色在线综合网站| 亚洲精品成人片在线观看精品字幕 | 亚洲av片在线观看| 亚洲av无码av在线播放| 色偷偷亚洲第一综合网| 亚洲av无码不卡私人影院| 女bbbbxxxx另类亚洲| 亚洲男人av香蕉爽爽爽爽| 国产成人亚洲综合无码| 亚洲人成网77777色在线播放| 久久亚洲精品国产精品黑人| 亚洲日本中文字幕| 亚洲免费二区三区| 亚洲中文字幕久久久一区| 亚洲av无一区二区三区| 亚洲精品人成无码中文毛片| 亚洲精品无码乱码成人| 亚洲综合在线成人一区| 亚洲欧洲日本在线观看| 无码国产亚洲日韩国精品视频一区二区三区| 噜噜噜亚洲色成人网站| 国产亚洲精品无码专区 | 中文日韩亚洲欧美制服|