DOM4J总结

 

DOM4J总结:
 
DOM4J 解析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 = "";
              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(newFileWriter("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);        
//更新document
代码:
   // 在指定位置修改
         public static void update()throws Exception{
                   /*
                    * 1、解析xml文档,将xml文档转换Dom4j树
                    * 2、利用dom4j树提供的导航方法找到需要修改的节点
                    * 3、修改指定的节点,或者在指定的节点添加新的节点
                    * 4、写入到dom4j树document中,写入修改后的xml文件中
                    * */
                   SAXReader reader = new SAXReader();
                   Document doc = reader.read(new File("src//bk.xml"));
                   Element root = doc.getRootElement();
                   Element book2 = (Element)root.elements("book").get(1);
                  List list = book2.elements();
                   Element address = DocumentHelper.createElement("address");
                   address.setText("保定");
                   list.add(2,address);
                   OutputFormat format = new OutputFormat("   ",true,"UTF-8");
                   XMLWriter xw = new XMLWriter(new FileWriter("src//bk.xml"),format);
                   xw.write(doc);
                   xw.close();
         }
//Bk.xml 文件
        
                   name文本1
                   author文本1
                   1000
        
        
                   name文本2
                   author文本2
                   100
                   100000
        
                  
                   name文本3
                   author文本3
                   100
                   100000
        
                  
                   name文本4
                   author文本4
                   100
                   100000
        
   // 利用dom4j 来创建xml 文档
public class Demo02 {
    public static void main(String[] args)throws Exception {
             //documentHelper的createDocument()方法创建document对象
             Document doc = DocumentHelper.createDocument();
             //或者是用DocumentFactory来创建
             /*DocumentFactory df = new DocumentFactory();
             Document doc1 = df.createDocument();*/    
             Element root = doc.addElement("books");              
             //添加四个元素
             Element book = root.addElement("book");
             book.addAttribute("isbn", "10001");
              Element name = book.addElement("name");
              name.setText("name 文本");
              Element author = book.addElement("author");
              author.setText("author 文本");
              Element price = book.addElement("price");
              price.setText("100");
             OutputFormat format = new OutputFormat("      ",true,"UTF-8");
                XMLWriter xw = new XMLWriter(new FileWriter("src//bk.xml"),format);     
              xw.write(doc);
              xw.close();
    }
}
   // 使用dom4j 解析xml 文档  解析元素  解析元素的文本  解析元素属性
public class Demo01 {
                  public static void main(String[] args) throws Exception {
                   // 读取器
                   SAXReader reader = new SAXReader();
                   // 读取xml文档 解析xml文档
                   Document doc = reader.read(new File("src//book.xml"));
                   // 获取根据节点
                   Element root = doc.getRootElement();
                   System.out.println(root.getName());
                   parse(root);
         }
         /*
          * //解析元素 public static void parse(Element root){ parseAttr(root);
          * List list = root.elements(); for(Element entity :list){
          * //判读是否只有文本 if(entity.isTextOnly()){ parseAttr(entity);
          * System.out.println(entity.getText()); }else{ parse(entity); } } }
          * //解析元素的属性 private static void parseAttr(Element root) {
          * List attrs = root.attributes();
          * System.out.println(attrs.size()); for(Attribute entity :attrs){
          * System.out.println(entity.getName()+"--------------"+entity.getValue());
          * }
          * }
          */
         // 解析元素
         public static void parse(Element root) {
                   parseAttr(root);
                   for (Iterator it = root.elementIterator(); it.hasNext();) {
                            Element entity = it.next();
                            // 判断是否只是文本
                            if (entity.isTextOnly()) {
                                     parseAttr(entity);
                                     System.out.println(entity.getText());
                            } else {
                                     parse(entity);
                            }
                   }
         }
         // 解析元素的属性
         private static void parseAttr(Element root) {
                   for (Iterator it = root.attributeIterator(); it.hasNext();) {
                            Attribute entity = it.next();
                            System.out.println(entity.getName() + "--------------"
                                               + entity.getValue());
                   }
         }
}

你可能感兴趣的:(DOM4J总结)