91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用dom4j讀取xml文件的四種方式介紹

發布時間:2020-03-23 18:05:11 來源:億速云 閱讀:251 作者:小新 欄目:編程語言

 使用dom4j讀取xml文件的方法有哪些呢?為了大家讓大家更加了解使用dom4j讀取xml文件的方法,小編給大家總結了以下內容,一起往下看吧。

使用dom4j讀取xml文件的四種方式介紹

以下是四種讀取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文件的四種方式大概了解了嗎?如果想了解更多,歡迎關注億速云行業資訊頻道哦!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

聂荣县| 枣强县| 扎囊县| 客服| 龙游县| 清水河县| 永春县| 大港区| 姜堰市| 丰镇市| 额济纳旗| 清苑县| 彭山县| 建阳市| 马关县| 兰考县| 长武县| 磐安县| 松潘县| 鄂托克前旗| 大宁县| 九江县| 南充市| 玛沁县| 南丰县| 凤台县| 囊谦县| 平乡县| 鄂托克旗| 舒兰市| 梧州市| 佛山市| 安龙县| 称多县| 昌宁县| 麻城市| 镇平县| 巴彦淖尔市| 兴安县| 淮南市| 麻栗坡县|