欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

dom4j读取xml资料

更新时间: 2014-01-05 02:01:38 责任编辑: Author_N1

 

DOM4J读取XML文件

     最近在做DRP的项目,其中涉及到了读取配置文件,用到了DOM4J,由于是刚开始接触这种读取xml文件的技术,好奇心是难免的,于是在网上又找了一些资料,这里就结合找到的资料来谈一下读取xml文件的4中方法。


XML文件

<?xml version="1.0" ?>
<ROWDATA>

<ROW>
  <C0>1</C0>
  <EMPNO>7891</EMPNO>
  <ENAME>sdffff</ENAME>
  <JOB>job</JOB>
  <MGR></MGR>
  <HIREDATE>2013-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>2012-12-17</HIREDATE>
  <SAL>800.00</SAL>
  <COMM></COMM>
  <DEPTNO>20</DEPTNO>
</ROW>

</ROWDATA>


下面是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文件更加的方便,更加的快捷,效率更高。

上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:01:38
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/4695/
本文WWW.DOC100.NET DOC100.NET版权所有。