国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

Dom4j解析xml文件

2019-11-10 17:16:45
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

dom4j是一個(gè)javaxml API,類(lèi)似于jdom,用來(lái)讀寫(xiě)XML文件的。dom4j是一個(gè)非常非常優(yōu)秀的Java XML API,具有性能優(yōu)異、功能強(qiáng)大和極端易用使用的特點(diǎn),同時(shí)它也是一個(gè)開(kāi)放源代碼的軟件,可以在SourceForge上找到它.

       對(duì)主流的Java XML API進(jìn)行的性能、功能和易用性的評(píng)測(cè),dom4j無(wú)論在那個(gè)方面都是非常出色的。如今你可以看到越來(lái)越多的Java軟件都在使用dom4j來(lái)讀寫(xiě)XML,例如hibernate,包括sun公司自己的JAXM也用了Dom4j。

       使用Dom4j開(kāi)發(fā),需下載dom4j相應(yīng)的jar文件

        1.官網(wǎng)下載: http://www.dom4j.org/dom4j-1.6.1/

         2.dom4j是sourceforge.NET上的一個(gè)開(kāi)源項(xiàng)目,因此可以到http://sourceforge.Net/PRojects/dom4j下載其最新版.

         對(duì)于下載的zip文件進(jìn)行解壓后的效果如下:

        

 打開(kāi)dom4j-1.6.1的解壓文件

在這里可以看到有docs幫助的文件夾,也有需要使用dom4j解析xml文件的dom4j-1.6.1.jar文件.我們只需要把dom4j-1.6.1.jar文件構(gòu)建到我們開(kāi)發(fā)的項(xiàng)目中就可以使用dom4j開(kāi)發(fā)了.

下面我以Myeclipse創(chuàng)建Java項(xiàng)目的構(gòu)建方法為例說(shuō)明.

首先創(chuàng)建一個(gè)demo項(xiàng)目,在demo項(xiàng)目中創(chuàng)建一個(gè)lib文件,把dom4j-1.6.1.jar文件拷貝到lib中,然后右鍵dom4j-1.6.1jar文件

   

點(diǎn)擊Add to Build Path即可構(gòu)建到項(xiàng)目中去了.

備注:如果進(jìn)行的是web項(xiàng)目開(kāi)發(fā),我們只需要把它拷貝到web-inf/lib中去即可,會(huì)自動(dòng)構(gòu)建到web項(xiàng)目中.

在項(xiàng)目開(kāi)發(fā)的過(guò)程中可以參考docs文件夾的(幫助文檔),找到index.html打開(kāi),點(diǎn)擊Quick start可以通過(guò)幫助文檔進(jìn)行學(xué)習(xí) dom4j進(jìn)行xml的解析.

    下面我對(duì)我認(rèn)為api中重要的方法進(jìn)行翻譯說(shuō)明如下:

一、DOM4j中,獲得Document對(duì)象的方式有三種:

[java] view plain copy1.讀取XML文件,獲得document對(duì)象                                SAXReader reader = new SAXReader();                        Document   document = reader.read(new File("csdn.xml"));  2.解析XML形式的文本,得到document對(duì)象.                    String text = "<csdn></csdn>";                                 Document document = DocumentHelper.parseText(text);  3.主動(dòng)創(chuàng)建document對(duì)象.                   Document document = DocumentHelper.createDocument();              //創(chuàng)建根節(jié)點(diǎn)                   Element root = document.addElement("csdn");  二、節(jié)點(diǎn)對(duì)象操作的方法

[java] view plain copy1.獲取文檔的根節(jié)點(diǎn).        Element root = document.getRootElement();      2.取得某個(gè)節(jié)點(diǎn)的子節(jié)點(diǎn).        Element element=node.element(“四大名著");      3.取得節(jié)點(diǎn)的文字          String text=node.getText();      4.取得某節(jié)點(diǎn)下所有名為“csdn”的子節(jié)點(diǎn),并進(jìn)行遍歷.          List nodes = rootElm.elements("csdn");             for (Iterator it = nodes.iterator(); it.hasNext();) {            Element elm = (Element) it.next();         // do something   }       5.對(duì)某節(jié)點(diǎn)下的所有子節(jié)點(diǎn)進(jìn)行遍歷.             for(Iterator it=root.elementIterator();it.hasNext();){                 Element element = (Element) it.next();                // do something     }      6.在某節(jié)點(diǎn)下添加子節(jié)點(diǎn)         Element elm = newElm.addElement("朝代");      7.設(shè)置節(jié)點(diǎn)文字.   elm.setText("明朝");      8.刪除某節(jié)點(diǎn).//childElement是待刪除的節(jié)點(diǎn),parentElement是其父節(jié)點(diǎn)  parentElement.remove(childElment);      9.添加一個(gè)CDATA節(jié)點(diǎn). Element contentElm = infoElm.addElement("content"); contentElm.addCDATA(“cdata區(qū)域”);  三、節(jié)點(diǎn)對(duì)象的屬性方法操作

[java] view plain copy1.取得某節(jié)點(diǎn)下的某屬性     Element root=document.getRootElement();         //屬性名name           Attribute attribute=root.attribute("id");      2.取得屬性的文字      String text=attribute.getText();      3.刪除某屬性  Attribute attribute=root.attribute("size");  root.remove(attribute);      4.遍歷某節(jié)點(diǎn)的所有屬性            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.設(shè)置某節(jié)點(diǎn)的屬性和文字.    newMemberElm.addAttribute("name", "sitinspring");      6.設(shè)置屬性的文字    Attribute attribute=root.attribute("name");    attribute.setText("csdn");  

四、將文檔寫(xiě)入XML文件

[java] view plain copy1.文檔中全為英文,不設(shè)置編碼,直接寫(xiě)入的形式.            XMLWriter writer = new XMLWriter(new  FileWriter("ot.xml"));           writer.write(document);            writer.close();      2.文檔中含有中文,設(shè)置編碼格式寫(xiě)入的形式.          OutputFormat format = OutputFormat.createPrettyPrint();// 創(chuàng)建文件輸出的時(shí)候,自動(dòng)縮進(jìn)的格式                           format.setEncoding("UTF-8");//設(shè)置編碼          XMLWriter writer = new XMLWriter(newFileWriter("output.xml"),format);          writer.write(document);          writer.close();  

五、字符串與XML的轉(zhuǎn)換

[java] view plain copy1.將字符串轉(zhuǎn)化為XML        String text = "<csdn> <java>Java班</java></csdn>";        Document document = DocumentHelper.parseText(text);      2.將文檔或節(jié)點(diǎn)的XML轉(zhuǎn)化為字符串.         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文件并對(duì)其進(jìn)行curd的操作)

1.sida.xml描述四大名著的操作,文件內(nèi)容如下

[html] view plain copy<?xml version="1.0" encoding="UTF-8"?>  <四大名著>      <西游記 id="x001">          <作者>吳承恩1</作者>          <作者>吳承恩2</作者>          <朝代>明朝</朝代>      </西游記>      <紅樓夢(mèng) id="x002">          <作者>曹雪芹</作者>      </紅樓夢(mèng)>  </四大名著>  2.解析類(lèi)測(cè)試操作

[java] view plain copypackage 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 {            // 創(chuàng)建saxReader對(duì)象          SAXReader reader = new SAXReader();          // 通過(guò)read方法讀取一個(gè)文件 轉(zhuǎn)換成Document對(duì)象          Document document = reader.read(new File("src/dom4j/sida.xml"));          //獲取根節(jié)點(diǎn)元素對(duì)象          Element node = document.getRootElement();          //遍歷所有的元素節(jié)點(diǎn)          listNodes(node);            // 獲取四大名著元素節(jié)點(diǎn)中,子節(jié)點(diǎn)名稱為紅樓夢(mèng)元素節(jié)點(diǎn)。          Element element = node.element("紅樓夢(mèng)");          //獲取element的id屬性節(jié)點(diǎn)對(duì)象          Attribute attr = element.attribute("id");          //刪除屬性          element.remove(attr);          //添加新的屬性          element.addAttribute("name", "作者");          // 在紅樓夢(mèng)元素節(jié)點(diǎn)中添加朝代元素的節(jié)點(diǎn)          Element newElement = element.addElement("朝代");          newElement.setText("清朝");          //獲取element中的作者元素節(jié)點(diǎn)對(duì)象          Element author = element.element("作者");          //刪除元素節(jié)點(diǎn)          boolean flag = element.remove(author);          //返回true代碼刪除成功,否則失敗          System.out.println(flag);          //添加CDATA區(qū)域          element.addCDATA("紅樓夢(mèng),是一部愛(ài)情小說(shuō).");          // 寫(xiě)入到一個(gè)新的文件中          writer(document);        }        /**      * 把document對(duì)象寫(xiě)入新的文件      *       * @param document      * @throws Exception      */      public void writer(Document document) throws Exception {          // 緊湊的格式          // OutputFormat format = OutputFormat.createCompactFormat();          // 排版縮進(jìn)的格式          OutputFormat format = OutputFormat.createPrettyPrint();          // 設(shè)置編碼          format.setEncoding("UTF-8");          // 創(chuàng)建XMLWriter對(duì)象,指定了寫(xiě)出文件及編碼格式          // 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);          // 寫(xiě)入          writer.write(document);          // 立即寫(xiě)入          writer.flush();          // 關(guān)閉操作          writer.close();      }        /**      * 遍歷當(dāng)前節(jié)點(diǎn)元素下面的所有(元素的)子節(jié)點(diǎn)      *       * @param node      */      public void listNodes(Element node) {          System.out.println("當(dāng)前節(jié)點(diǎn)的名稱::" + node.getName());          // 獲取當(dāng)前節(jié)點(diǎn)的所有屬性節(jié)點(diǎn)          List<Attribute> list = node.attributes();          // 遍歷屬性節(jié)點(diǎn)          for (Attribute attr : list) {              System.out.println(attr.getText() + "-----" + attr.getName()                      + "---" + attr.getValue());          }            if (!(node.getTextTrim().equals(""))) {              System.out.println("文本內(nèi)容::::" + node.getText());          }            // 當(dāng)前節(jié)點(diǎn)下面子節(jié)點(diǎn)迭代器          Iterator<Element> it = node.elementIterator();          // 遍歷          while (it.hasNext()) {              // 獲取某個(gè)子節(jié)點(diǎn)對(duì)象              Element e = it.next();              // 對(duì)子節(jié)點(diǎn)進(jìn)行遍歷              listNodes(e);          }      }        /**      * 介紹Element中的element方法和elements方法的使用      *       * @param node      */      public void elementMethod(Element node) {          // 獲取node節(jié)點(diǎn)中,子節(jié)點(diǎn)的元素名稱為西游記的元素節(jié)點(diǎn)。          Element e = node.element("西游記");          // 獲取西游記元素節(jié)點(diǎn)中,子節(jié)點(diǎn)為作者的元素節(jié)點(diǎn)(可以看到只能獲取第一個(gè)作者元素節(jié)點(diǎn))          Element author = e.element("作者");            System.out.println(e.getName() + "----" + author.getText());            // 獲取西游記這個(gè)元素節(jié)點(diǎn) 中,所有子節(jié)點(diǎn)名稱為作者元素的節(jié)點(diǎn) 。            List<Element> authors = e.elements("作者");          for (Element aut : authors) {              System.out.println(aut.getText());          }            // 獲取西游記這個(gè)元素節(jié)點(diǎn) 所有元素的子節(jié)點(diǎn)。          List<Element> elements = e.elements();            for (Element el : elements) {              System.out.println(el.getText());          }        }    }  自己適當(dāng)注釋部分代碼觀察運(yùn)行效果,反復(fù)練習(xí),希望你對(duì)dom4j有進(jìn)一步的了解.

七、字符串與XML互轉(zhuǎn)換案例

[java] view plain copypackage 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 {            // 創(chuàng)建saxreader對(duì)象          SAXReader reader = new SAXReader();          // 讀取一個(gè)文件,把這個(gè)文件轉(zhuǎn)換成Document對(duì)象          Document document = reader.read(new File("src//c.xml"));          // 獲取根元素          Element root = document.getRootElement();          // 把文檔轉(zhuǎn)換字符串          String docXmlText = document.asXML();          System.out.println(docXmlText);          System.out.println("---------------------------");          // csdn元素標(biāo)簽根轉(zhuǎn)換的內(nèi)容          String rootXmlText = root.asXML();          System.out.println(rootXmlText);          System.out.println("---------------------------");          // 獲取java元素標(biāo)簽 內(nèi)的內(nèi)容          Element e = root.element("java");          System.out.println(e.asXML());        }        /**      * 創(chuàng)建一個(gè)document對(duì)象 往document對(duì)象中添加節(jié)點(diǎn)元素 轉(zhuǎn)存為xml文件      *       * @throws Exception      */      public void test2() throws Exception {            Document document = DocumentHelper.createDocument();// 創(chuàng)建根節(jié)點(diǎn)          Element root = document.addElement("csdn");          Element java = root.addElement("java");          java.setText("java班");          Element ios = root.addElement("ios");          ios.setText("ios班");            writer(document);      }        /**      * 把一個(gè)文本字符串轉(zhuǎn)換Document對(duì)象      *       * @throws Exception      */      public void test1() throws Exception {          String text = "<csdn><java>Java班</java><net>Net班</net></csdn>";          Document document = DocumentHelper.parseText(text);          Element e = document.getRootElement();          System.out.println(e.getName());          writer(document);      }        /**      * 把document對(duì)象寫(xiě)入新的文件      *       * @param document      * @throws Exception      */      public void writer(Document document) throws Exception {          // 緊湊的格式          // OutputFormat format = OutputFormat.createCompactFormat();          // 排版縮進(jìn)的格式          OutputFormat format = OutputFormat.createPrettyPrint();          // 設(shè)置編碼          format.setEncoding("UTF-8");          // 創(chuàng)建XMLWriter對(duì)象,指定了寫(xiě)出文件及編碼格式          // 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);          // 寫(xiě)入          writer.write(document);          // 立即寫(xiě)入          writer.flush();          // 關(guān)閉操作          writer.close();      }  }  


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 黑水县| 丹江口市| 洛浦县| 中西区| 樟树市| 精河县| 西平县| 龙陵县| 东山县| 云林县| 尼木县| 余干县| 灵丘县| 临江市| 高雄县| 德钦县| 麻江县| 赣州市| 成都市| 平遥县| 丰都县| 原平市| 砀山县| 胶南市| 怀化市| 河北省| 托克逊县| 洞口县| 滨州市| 汪清县| 栾城县| 社会| 建水县| 全南县| 黄龙县| 鱼台县| 商洛市| 射洪县| 鱼台县| 潞城市| 灵山县|