以下是四种读取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的方式。不过在此处我没有列出。如果有知道其他方式的朋友欢迎回帖。一起研究。
分享到:
相关推荐
基于dom4j的读写xml文件的工具包。封装了dom4j操作xml文档的常和方法。 支持两种读写方法。1:针对小文件的读取整个文档,2:针对大文件的,逐行读取。读到几百M文件毫无压力。
Dom4j解析XML文档.doc Dom4j解析XML文档.doc Dom4j解析XML文档.doc Dom4j解析XML文档.doc
NULL 博文链接:https://sxpujs.iteye.com/blog/375485
使用dom4j读取xml四种方法,希望对各位朋友有所帮助
详细介绍了使用Dom4j进行xml文件的读取方法
dom4j读写xmldom4j读写xmldom4j读写xmldom4j读写xmldom4j读写xml
dom4j解析xml文件代码示例 dom4j解析xml文件代码示例 dom4j解析xml文件代码示例
Dom4j解析教程。详细讲解如何使用dom4j解析xml,简单易懂。
java中dom4j读写XML(项目中含所需要的jar包)
使用dom4j读写XML文档 1.获取文档的根节点. Element rootElm = document.getRootElement(); 2.取得某节点的单个子节点. Element memberElm=root.element("member");// "member"是节点名 3.取得节点的文字 String ...
dom4j是非常优秀的xml解析包,操作起来读写xml非常方便。把自己写的一个读写dom4j.xml实例共享给大家
Dom4j 读写 XML
简单的读取xml,利用dom4j读写xml实例xmldemo
使用dom4j对xml的读写(这个感觉比jdom功能好点,但是复杂一点点)
Dom4j是一个开源的Java XML 解析处理工具,用来读写XML文件,它应用于Java平台,采用了Java集合框架并完全支持DOM, SAX和JAXP。具有性能优异、功能强大和极易使用的特点。可以作为解析XML文档析首先API。本文讲述了...
使用dom4j对xml文档进行增删改. 查询就不用说了,使用elements(....)/element(...)/attributeValue()/getText()等方法
读取XML文件的四种方法,详细介绍了dom,jdom,dom4j,sax
利用dom4j--读取xml文件。 代码简洁易懂。
本文件主要介绍我们怎么从dom4j中读取xml文件中的信息
使用DOM4j技术快速解析XML文件,提高开发效率