您的位置:首页 > 其它

使用dom4j四种读取xml文件的方法

2014-09-07 11:29 387 查看


使用dom4j四种读取xml文件的方法  

我们先给出一个简单的xml文件

<?xml version="1.0" ?>

<ROWDATA>

<ROW>

  <C0>1</C0>

  <EMPNO>7891</EMPNO>

  <ENAME>sdffff</ENAME>

  <JOB>job</JOB>

  <MGR></MGR>

  <HIREDATE>2010-1-1</HIREDATE>

  <SAL>5000.00</SAL>

  <COMM>1000.00</COMM>

  <DEPTNO></DEPTNO>

</ROW>

<ROW>

  <C0>2</C0>

  <EMPNO>7369</EMPNO>

  <ENAME>SMITH</ENAME>

  <JOB>CLERK</JOB>

  <MGR>7902</MGR>

  <HIREDATE>1980-12-17</HIREDATE>

  <SAL>800.00</SAL>

  <COMM></COMM>

  <DEPTNO>20</DEPTNO>

</ROW>

</ROWDATA>

第一种:

/**

  * 使用dom4j 中saxreader 获取Document容器,利用此容器的elementIterator读取xml文件

  */

 public static void readXML() throws DocumentException{

  

  SAXReader sr = new SAXReader();//获取读取xml的对象。

  Document doc = sr.read("src/com/sinojava/EMP.xml");//得到xml所在位置。然后开始读取。并将数据放入doc中

  Element el_root = doc.getRootElement();//向外取数据,获取xml的根节点。

  Iterator it = el_root.elementIterator();//从根节点下依次遍历,获取根节点下所有子节点

  

  while(it.hasNext()){//遍历该子节点

   

   Object o = it.next();//再获取该子节点下的子节点

   Element el_row = (Element)o;

   String s = el_row.getText();

   Iterator it_row = el_row.elementIterator();

   

   while(it_row.hasNext()){//遍历节点

    

    Element el_ename = (Element)it_row.next();//获取该节点下的所有数据。

    System.out.println(el_ename.getText());

   }

   //System.out.println(o);

  }

  

 }

 

第二种

 

/**

  * 使用elements方法进行xml的读取,相当于条件查询,可以根据不同的节点,利用for循环查询该节点下所有的数据。

  * @throws DocumentException

  */

 public static void readXML02() throws DocumentException{

  

  SAXReader sr = new SAXReader();//获取读取方式

  Document doc = sr.read("src/com/sinojava/EMP.xml");//读取xml文件,并且将数据全部存放到Document中

  Element root = doc.getRootElement();//获取根节点

  

  List list = root.elements("ROW");//根据根节点,将根节点下 row中的所有数据放到list容器中。

  for(Object obj:list){//这种遍历方式,是jdk1.5以上的版本支持的遍历方式

   Element row = (Element)obj;

   List list_row = row.elements("ENAME");//获取ENAME节点下所有的内容,存入list_row容器中

   

   for(Object objempno:list_row){

    

    Element el_empno = (Element)objempno;

    

    System.out.println(el_empno.getName()+": "+el_empno.getText());//获取节点下的数据。

    

   }

  }

 }

 

第三种:

/**

  * 使用适配器来完成xml的读取。

  * @param args

  * @throws DocumentException 

  */

 public static void readXML04() throws DocumentException{

  

  SAXReader sr = new SAXReader();

  Document doc = sr.read("src/com/sinojava/EMP.xml");

  

  doc.accept(new VisitorSupport() {//使用观察器的子类,来完成对xml文件的读取。

   

   public void visit(Element el) {//利用观察期进行xml的读取。

    

    System.out.println(el.getName()+": "+el.getText());

   }

   

  });

 }

 

第四种:

/**

  * 使用selectNodes读取xml文件

  * @param args

  * @throws DocumentException 

  */

 public static void readXML05(String elementpath) throws DocumentException{

  

  SAXReader sr = new SAXReader();

  Document doc = sr.read("src/com/sinojava/EMP.xml");

  

  List list = doc.selectNodes(elementpath);//使用selectNodes获取所要查询xml的节点。

  

  for(Object obj:list){//遍历节点,获取节点内数据。

   

   Element el = (Element)obj;

   System.out.println(el.getText());

  }

  

 }

 

以上四种都是使用dom4j来读取xml文件。是比较常见的四种方式。当然还有其他的不用dom4j的方式。不过在此处我没有列出。如果有知道其他方式的朋友欢迎回帖。一起研究。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: