DOM4J 实现对XML文档的增、删、改、查

前言:首先谈一个小故事:当年Java准备做对XML的解析时,对解析器的实现方向在内部发生了争执,后来高层没有听从工程师建议,坚持开发出了JDOM,而主要的工程师选择离开Java 按照自己的方式实现,就是DOM4J 。后来结果表明,DOM4J 完胜了JDOM。下面,让我们来了解一下通过DOM4J 实现对XML文件进行增删改查的过程。

1、待解析的XML文件:

<span style="font-size:14px;">
<?xml version="1.0" encoding="utf-8"?>

<students xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
		xmlns="http://www.itcast.cn/xml"
			xsi:schemaLocation="http://www.itcast.cn/xml students.xsd">
	<student number="ITCAST_1001">
	  <name>zhangSan</name>
	  <age>23</age>
	  <sex>male</sex>
	</student>
</students>

</span>

2、用DOM4J实现增删改查:
<span style="font-size:14px;">
public class Demo3 {

	@Test
	public void method1() throws Exception {
		// 创建解析器
		SAXReader reader = new SAXReader();//这个是用来读取文件内容的
		Document doc = reader.read(new File("students.xml")); //指定要读取的文件
		//System.out.println(doc.asXML()); //打印出文件
	}
	
	//实现对XML文件的复制
	@Test
	public void method2() throws Exception {
		// 得到Document
		SAXReader reader = new SAXReader();
		Document doc = reader.read(new File("students.xml"));
		
		// 保存Document,指定将写入的目的文件(复制功能)
		XMLWriter writer = new XMLWriter(new FileOutputStream("students_copy.xml"));
		writer.write(doc); //开始写入
	}
	
	//遍历Document
	@Test
	public void method3() throws Exception {
		// 要遍历文档,首先要得到Document对象
		SAXReader reader = new SAXReader();
		Document doc = reader.read(new File("students.xml"));

		//获取根元素
		Element root = doc.getRootElement();
		//获取根元素中所有student元素
		List<Element> stuEleList = root.elements("student");
		// 循环遍历所有学生元素
		for(Element stuEle : stuEleList) {
			//获取学生元素的number
			String number = stuEle.attributeValue("number");
			//获取学生元素名为name的子元素的文本内容
			String name = stuEle.elementText("name");
			//获取学生元素名为age的子元素的文本内容
			String age = stuEle.elementText("age");
			//获取学生元素名为sex的子元素的文本内容
			String sex = stuEle.elementText("sex");		
			System.out.println(number + ", " + name + ", " + age + ", " + sex);
		}
	}
	
	//添加元素
	@Test
	public void method4() throws Exception {
		// 得到Document
		SAXReader reader = new SAXReader();
		Document doc = reader.read(new File("src/students.xml"));

		//获取root元素
		Element root = doc.getRootElement();
		Element stuEle = root.addElement("student"); //添加了student元素
		// 给stuEle添加属性,名为number,值为1003
		stuEle.addAttribute("number", "1003"); 
		// 分别为stuEle添加名为name、age、sex的子元素,并为子元素设置文本内容
		stuEle.addElement("name").setText("wangWu");
		stuEle.addElement("age").setText("18");
		stuEle.addElement("sex").setText("male");
		
		// 设置保存的格式化器  1. \t,使用什么来完成缩进 2. true, 是否要添加换行
		OutputFormat format = new OutputFormat("\t", true);
		format.setTrimText(true); //去掉空白
		// 在创建Writer时,指定格式化器
		XMLWriter writer = new XMLWriter(new FileOutputStream("src/students_copy.xml"), format);
		writer.write(doc);
	}
	
	//修改元素
	@Test
	public void method5() throws Exception {

		// 得到Document
		SAXReader reader = new SAXReader();
		Document doc = reader.read(new File("src/students_copy.xml"));

		//使用XPath找到符合条件的元素
		// 查询student元素,条件是number属性的值为1003
		Element stuEle = (Element) doc.selectSingleNode("//student[@number='ITCAST_1003']");
		//修改stuEle的age子元素内容为81
		stuEle.element("age").setText("81");
		//修改stuEle的sex子元素的内容为female
		stuEle.element("sex").setText("female");

	}
	
	//删除元素
	@Test
	public void method6() throws Exception {

		// 得到Document
		SAXReader reader = new SAXReader();
		Document doc = reader.read(new File("src/students_copy.xml"));
		
		// 查找student元素,条件是name子元素的文本内容为wangWu
		Element stuEle = (Element) doc.selectSingleNode("//student[name='wangWu']");
		
		// 2. 获取父元素,使用父元素删除指定子元素
		stuEle.getParent().remove(stuEle);
	}
}
 </span>
  小结: DOM4J 无论在那个方面都是非常出色的。如今越来越多的Java软件在使用DOM4J来读写XML,例如Hibernate,包括sun公司自己的JAXM也用了DOM4J。

DOM4J 实现对XML文档的增、删、改、查_第1张图片


你可能感兴趣的:(java,xml,jdom,dom4j,javaweb)