使用dom4j四種讀取xml檔案的方法
原文地址:http://blog.163.com/chenhui_java/blog/static/172672494201092632424462/
以下是四種讀取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的方式。不過在此處我沒有列出。如果有知道其他方式的朋友歡迎回帖。一起研究。