dom4j生成或解析xml文档

来源:互联网 发布:linux 切换主机 编辑:程序博客网 时间:2024/04/28 03:58

 xml是一种新的数据格式,主要用于数据交换。我们所用的框架都有涉及到xml。因此解析或生成xml对程序员也是一个技术难点。这里就用dom4j来生成一个文档,需要注意的是每个xml文档只有一个根节点。

[java] view plaincopy
  1. package org.lxh;  
  2.   
  3. import java.io.File;  
  4. import java.io.FileNotFoundException;  
  5. import java.io.FileOutputStream;  
  6. import java.io.UnsupportedEncodingException;  
  7.   
  8. import org.dom4j.Document;  
  9. import org.dom4j.DocumentHelper;  
  10. import org.dom4j.Element;  
  11. import org.dom4j.io.OutputFormat;  
  12. import org.dom4j.io.XMLWriter;  
  13.   
  14. public class CreateXml {  
  15.   
  16.       
  17.     public static void main(String[] args) {  
  18.         File f=new File("d:"+File.separator+"my.xml");    
  19.         Document docu=DocumentHelper.createDocument();  //创建xml文档  
  20.         Element linkman=docu.addElement("linkman");   //创建根节点  
  21.          
  22.         Element name=linkman.addElement("name");  //创建子元素  
  23.         Element age=linkman.addElement("age");  
  24.         name.setText("陈瑞银");   //设置name节点的内容  
  25.         age.setText("22");        //设置age节点的内容  
  26.          
  27.         OutputFormat format=OutputFormat.createPrettyPrint();  //指定输出格式  
  28.         format.setEncoding("UTF-8");    //指定输出编码  
  29.         try {  
  30.             XMLWriter w=new XMLWriter(new FileOutputStream(f),format);  //输出文件  
  31.             w.write(docu);  //输出内容  
  32.             w.close();  
  33.         } catch (Exception e) {  
  34.             // TODO Auto-generated catch block  
  35.             e.printStackTrace();  
  36.         }   
  37.     }  
  38.   
  39. }  


现在看一下文档生成没有,如图所示

文档生成了,这个文档比较简单。生成复杂的文档也是一样的道理。下面来解析一下这个xml。

代码如下所示

[java] view plaincopy
  1. package org.lxh;  
  2.   
  3. import java.io.File;  
  4. import java.util.Iterator;  
  5.   
  6. import org.dom4j.*;  
  7. import org.dom4j.io.SAXReader;  
  8.   
  9. public class ReadXml {  
  10.   
  11.     public static void main(String[] args) {  
  12.         File f=new File("d:"+File.separator+"my.xml");  
  13.         SAXReader read=new SAXReader();   //建立SAX解析读取  
  14.         Document document=null;  
  15.         try {  
  16.             document=read.read(f);   //读取文档  
  17.             Element root=document.getRootElement();   //取得根元素  
  18.             //下面给注释的部分用于解析复杂的xml(3层或以上)  
  19.             /*Iterator it=root.elementIterator();    //取得全部子节点 
  20.             while(it.hasNext()) 
  21.             { 
  22.                 /*Element e=(Element)it.next(); 
  23.                 System.out.println(e.elementText("name"));  //取得文本元素 
  24.                 System.out.println(e.elementText("age")); 
  25.                  
  26.             }*/  
  27.             System.out.println(root.elementText("age"));  
  28.         } catch (Exception e) {  
  29.             // TODO Auto-generated catch block  
  30.             e.printStackTrace();  
  31.         }  
  32. }  
  33. }  


下面是运行效果截图

原创粉丝点击