Dom4J解析xml文件
发布日期:2021-07-26 18:44:05 浏览次数:0 分类:技术文章

(一)xml基础简介:

什么是xml?
-可扩展标记语言,根据自己的需求定义自己的标签。

xml文件的作用:
-主要用来传输和存储数据。

解析xml文件的方法:
-DOM、DOM4J、SAX
-DOM与DOM4J:基于树结构的解析(一次性读取到内存中需要什么解析什么)。注:DOM复杂繁琐,DOM4J对DOM进行了封装,建议使用DOM4J。
-SAX:基于事件流的解析(边读边解析,不回头),适用于大的xml文件。

 

xml文档练习(方便后面说明):

read_student.xml :

<?xml version="1.0" encoding="UTF-8"?><students>	<student id="1">		<name>王同</name>		<course>java</course>		<score>89</score>	</student>	<student id="2">		<name>李佳</name>		<course>sql</course>		<score>58</score>	</student></students>

 

(二)Dom4J解析

1)Dom4J常用对象:
SAXReader:读取xml文件到Document树结构文件对象。
Document:是一个xml文档对象树,类比Html文档对象。
Element:元素节点。通过Document对象可以查找单个元素。

2)Dom4J解析read_student.xml步骤:
第一步:创建解析器。
第二步:得到Document对象。
第三步:获取xml根节点。
第四步:遍历解析子节点。

解析read_student.xml文件

方法1:

package Test;import java.io.File;import java.util.Iterator;import org.dom4j.Attribute;import org.dom4j.Document;import org.dom4j.DocumentException;import org.dom4j.Element;import org.dom4j.io.SAXReader;public class a_SAX {	public static void main(String[] args) throws DocumentException{		//创建解析器		SAXReader reader =new SAXReader();		//通过解析器的read方法将配置文件读到内存中,生成一个Document[org.dom4j]对象树		Document document=reader.read(new File("conf/Student.xml"));		//获取根节点		Element root=document.getRootElement();		//开始遍历根节点(迭代器)		Iterator<Element> rootIter=root.elementIterator();		while(rootIter.hasNext()){			//获取root下的元素			Element e=(Element)rootIter.next();			System.out.println(e.getName());			//获取id属性			Attribute id=e.attribute("id");			System.out.println(id.getName()+"="+id.getValue());			//获取student的子元素			Element name=e.element("name");			Element course=e.element("course");			Element score=e.element("score");			System.out.println(name.getName()+"="+name.getText());			System.out.println(course.getName()+"="+course.getText());			System.out.println(score.getName()+"="+score.getText());			System.out.println("--------------------------------------------");		}	}}

方法2:

package Test;import java.io.File;import java.util.Iterator;import org.dom4j.Attribute;import org.dom4j.Document;import org.dom4j.DocumentException;import org.dom4j.Element;import org.dom4j.io.SAXReader;public class b_SAX {	public static void main(String[] args) throws DocumentException{		//创建解析器		SAXReader reader =new SAXReader();		//通过解析器的read方法将配置文件读到内存中,生成一个Document[org.dom4j]对象树		Document document=reader.read(new File("conf/Student.xml"));		//获取根节点		Element root=document.getRootElement();		//开始遍历根节点(迭代器)		Iterator<Element> rootIter=root.elementIterator();		while(rootIter.hasNext()){			//获取rot下的元素			Element e=(Element)rootIter.next();			System.out.print(e.getName()+"  ");			//获取id属性			Attribute id=e.attribute("id");				System.out.println(id.getName()+"="+id.getValue());			//获取student的子元素			Iterator<Element> node=e.elementIterator();			while(node.hasNext()){				Element innerElt=node.next();				System.out.println(innerElt.getName()+"="+innerElt.getText());			}			System.out.println("--------------------------------------------");		}	}}

结果:

 

 

上一篇:XML备份mysql数据库
下一篇:JAVA基础:Super()详解