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 }

 

posted @ 2015-06-07 21:27  woodrow_woo  阅读(139)  评论(0编辑  收藏  举报