zoukankan      html  css  js  c++  java
  • 007_01DOM4J解析XML文档

      Dom4j是一个简单、灵活的开放源代码的库。Dom4j是由早期开发JDOM的人分离出来而后独立开发的。与JDOM不同的是,dom4j使用接口和抽象基类,虽然Dom4j的API相对要复杂一些,但它提供了比JDOM更好的灵活性。

      Dom4j是一个非常优秀的Java XML API,具有性能优异、功能强大和极易使用的特点。现在很多软件采用的Dom4j,例如Hibernate,包括sun公司自己的JAXM也用了Dom4j。 使用Dom4j开发,需下载dom4j相应的jar文件。

    DOM4j中,获得Document对象的方式有三种:

      1.读取XML文件,获得document对象

        SAXReader reader = new SAXReader();

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

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

        String text = "<members></members>";             

        Document document = DocumentHelper.parseText(text);

      3.主动创建document对象.             

        Document document = DocumentHelper.createDocument();             //创建根节点

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

    节点对象:

      1.获取文档的根节点. Element root = document.getRootElement();

      2.取得某个节点的子节点. Element element=node.element(“书名");

      3.取得节点的文字 String text=node.getText();

      4.取得某节点下所有名为“member”的子节点,并进行遍历.

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

        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 ageElm = newMemberElm.addElement("age");

      7.设置节点文字. element.setText("29");

      8.删除某节点. //childElm是待删除的节点,parentElm是其父节点 parentElm.remove(childElm);

      9.添加一个CDATA节点.

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

        contentElm.addCDATA(diary.getContent());

    节点对象属性:

      1.取得某节点下的某属性    

        Element root=document.getRootElement();        //属性名name

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

      2.取得属性的文字    String text=attribute.getText();

      3.删除某属性

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

        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("sitinspring");

    将文档写入XML文件

      1.文档中全为英文,不设置编码,直接写入的形式.

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

        writer.write(document); writer.close();

      2.文档中含有中文,设置编码格式写入的形式.

         OutputFormat format = OutputFormat.createPrettyPrint(); // 指定XML编码 

        format.setEncoding("GBK");                                       

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

         writer.write(document);

         writer.close();

    Dom4j在指定位置插入节点

      1.得到插入位置的节点列表(list)

      2.调用list.add(index,elemnent),由index决定element的插入位置。

      Element元素可以通过DocumentHelper对象得到。

      示例代码:

         Element aaa = DocumentHelper.createElement("aaa");

         aaa.setText("aaa"); List list = root.element("书").elements();

         list.add(1, aaa);

    实例:

      1 package com.cskaoyan.dom4j;
      2 
      3 import java.io.FileOutputStream;
      4 import java.io.FileWriter;
      5 
      6 import org.dom4j.Document;
      7 import org.dom4j.DocumentException;
      8 import org.dom4j.Element;
      9 import org.dom4j.io.OutputFormat;
     10 import org.dom4j.io.SAXReader;
     11 import org.dom4j.io.XMLWriter;
     12 
     13 public class Dom4jDeom {
     14 
     15     /**
     16      * @param args
     17      * @throws Exception 
     18      */
     19     public static void main(String[] args) throws Exception {
     20         // TODO Auto-generated method stub
     21         
     22         // 23         // 24         // 25         // 26         
     27         //查找第二本书的价格:
     28             //第一步,解析xml文件,获取解析后的document对象;
     29 /*          SAXReader reader = new SAXReader();
     30             Document document = reader.read("src/books.xml");
     31             //第二部,获取根节点信息
     32             Element root = document.getRootElement();
     33             //第三步,获取对应节点,应得到想要的信息         
     34             Element book1 =   (Element) root.elements().get(1);
     35             Element price =   (Element) book1.element("author");
     36             // System.out.println( price.getText());
     37             book1.remove(price);*/
     38              
     52             //
     53             /*SAXReader reader = new SAXReader();
     54             Document document = reader.read("src/books.xml");
     55             Element root = document.getRootElement();
     56             Element book1 =   (Element) root.elements().get(1);
     57             Element author =  book1.addElement("author");
     58             author.setText("李开复");
     59             
     60             OutputFormat format = OutputFormat.createPrettyPrint();// 指定XML编码                   
     61             format.setEncoding("utf-8"); 
     62             XMLWriter writer = new XMLWriter(new FileOutputStream ("src/books.xml"),format);
     63             writer.write(document); 
     64             writer.close();*/
     65             
     66             //
     67             /*SAXReader reader = new SAXReader();
     68             Document document = reader.read("src/books.xml");
     69              Element root = document.getRootElement();
     70              Element book1 =   (Element) root.elements().get(1);
     71             Element author =   (Element) book1.element("author");
     72             author.setText("吴军");
     73             
     74             OutputFormat format = OutputFormat.createPrettyPrint();// 指定XML编码                   
     75             format.setEncoding("utf-8"); 
     76             XMLWriter writer = new XMLWriter(new FileOutputStream ("src/books.xml"),format);
     77             writer.write(document); 
     78             writer.close();*/
     79             
     80          
     81          //   XPATH
     82         
     83         SAXReader reader = new SAXReader();
     84         Document document = reader.read("src/books.xml");
     85         
     86         Element priceElement = (Element) document.selectNodes("books/book/*").get(3); 
     87          
     88         System.out.println( priceElement.getText());
     89 
     90         //第三步,获取对应节点,应得到想要的信息         
     91         /*Element book1 =   (Element) root.elements().get(1);
     92         Element price =   (Element) book1.element("author");*/
     93        // System.out.println( price.getText());
     94         
     95        //使用xpath 去实现节点的增删改查操作!
     96         
     97             
     98     }
     99 
    100 }
    物随心转,境由心造,一切烦恼皆由心生。
  • 相关阅读:
    python lambda
    Java使用Graphics2D生成公章
    纯前端Html+JavaScript+canvas生成公章
    MySQL 大表优化方案,收藏了细看!
    【全干货】5分钟带你看懂 Docker!
    MySQL 分页优化中的 “ INNER JOIN方式优化分页算法 ” 到底在什么情况下会生效?...
    React-Native iOS真机调试(新版)
    React-Native iOS真机调试(新版)
    React-Native iOS真机调试(新版)
    React-Native iOS真机调试(新版)
  • 原文地址:https://www.cnblogs.com/woodrow2015/p/4555055.html
Copyright © 2011-2022 走看看