国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
使用dom4j讀取xml文檔的四種方式
以下是四種讀取xml文件的方式,每種都有自己的用處。這是我在寫日志管理器的時候查找到的。希望能給大家?guī)椭?/div>
首先我們先給出一個簡單的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所在位置。然后開始讀取。并將數(shù)據(jù)放入doc中
  Element el_root = doc.getRootElement();//向外取數(shù)據(jù),獲取xml的根節(jié)點。
  Iterator it = el_root.elementIterator();//從根節(jié)點下依次遍歷,獲取根節(jié)點下所有子節(jié)點
 
  while(it.hasNext()){//遍歷該子節(jié)點
  
   Object o = it.next();//再獲取該子節(jié)點下的子節(jié)點
   Element el_row = (Element)o;
   String s = el_row.getText();
   Iterator it_row = el_row.elementIterator();
  
   while(it_row.hasNext()){//遍歷節(jié)點
   
    Element el_ename = (Element)it_row.next();//獲取該節(jié)點下的所有數(shù)據(jù)。
    System.out.println(el_ename.getText());
   }
   //System.out.println(o);
  }
 
 }
第二種
/**
  * 使用elements方法進行xml的讀取,相當于條件查詢,可以根據(jù)不同的節(jié)點,利用for循環(huán)查詢該節(jié)點下所有的數(shù)據(jù)。
  * @throws DocumentException
  */
 public static void readXML02() throws DocumentException{
 
  SAXReader sr = new SAXReader();//獲取讀取方式
  Document doc = sr.read("src/com/sinojava/EMP.xml");//讀取xml文件,并且將數(shù)據(jù)全部存放到Document中
  Element root = doc.getRootElement();//獲取根節(jié)點
 
  List list = root.elements("ROW");//根據(jù)根節(jié)點,將根節(jié)點下 row中的所有數(shù)據(jù)放到list容器中。
  for(Object obj:list){//這種遍歷方式,是jdk1.5以上的版本支持的遍歷方式
   Element row = (Element)obj;
   List list_row = row.elements("ENAME");//獲取ENAME節(jié)點下所有的內(nèi)容,存入list_row容器中
  
   for(Object objempno:list_row){
   
    Element el_empno = (Element)objempno;
   
    System.out.println(el_empno.getName()+": "+el_empno.getText());//獲取節(jié)點下的數(shù)據(jù)。
   
   }
  }
 }
 
第三種:
/**
  * 使用適配器來完成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的節(jié)點。
 
  for(Object obj:list){//遍歷節(jié)點,獲取節(jié)點內(nèi)數(shù)據(jù)。
  
   Element el = (Element)obj;
   System.out.println(el.getText());
  }
 
 }
 
以上四種都是使用dom4j來讀取xml文件。是比較常見的四種方式。當然還有其他的不用dom4j的方式。不過在此處我沒有列出。如果有知道其他方式的朋友歡迎回帖。一起研究。
 
本文來自CSDN博客,轉(zhuǎn)載請標明出處:http://blog.csdn.net/chenhui917/archive/2010/10/26/5966897.aspx
本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
生活服務(wù)
分享 收藏 導長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服