java dom4j 读xml文件_DOM4J读取XML文件

XML文件<?xml  version="1.0" ?>

1

7891

sdffff

job

2013-1-1

5000.00

1000.00

2

7369

SMITH

CLERK

7902

2012-12-17

800.00

20

下面是DOM4J读取XML文件的方式:

1. SAXReader/**

* 使用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);

}

}

2. Elements/**

* 使用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());//获取节点下的数据。

}

}

}

3. 适配器/**

* 使用适配器来完成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());

}

});

}

4. SelectNodes/**

* 使用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());

}

}

以上4种方式都是使用DOM4J读取XML文件的方式,都比较常见。DRP中用到的是SAXReader方式,由于只是读取配置文件中的JDBC的设置,所以还是比较简单的。

Dom4j是一个易用的、开源的库,用于XML,XPath和XSLT。它应用于Java平台,采用了Java集合框架并完全支持DOM,SAX和JAXP。Dom4j使用起来非常简单,它的主要接口都在com.dom4j这个包里定义的,例如,我们的代码中要引入几个命名空间(import org.dom4j.io.SAXReader;等等)。

Dom4j使得Java读取XML文件更加的方便,更加的快捷,效率更高。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值