Dom4J解析xml文件

(一)xml基础简介:

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

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

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

 

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

Dom4J解析xml文件_第1张图片

read_student.xml :



	
		王同
		java
		89
	
	
		李佳
		sql
		58
	

 

(二)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 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 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 node=e.elementIterator();
			while(node.hasNext()){
				Element innerElt=node.next();
				System.out.println(innerElt.getName()+"="+innerElt.getText());
			}
			System.out.println("--------------------------------------------");
		}
	}

}

结果:
Dom4J解析xml文件_第2张图片

 

 

你可能感兴趣的:(XML)