【XML】利用Dom4j读取XML文档以及写入XML文档

Dom4j简介

dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的。dom4j是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,它的性能超过sun公司官方的dom技术,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。在IBM developerWorks上面还可以找到一篇文章,对主流的Java XML API进行的性能、功能和易用性的评测,所以可以知道dom4j无论在哪个方面都是非常出色的。如今可以看到越来越多的Java软件都在使用dom4j来读写XML,特别值得一提的是连Sun的JAXM也在用dom4j。这已经是必须使用的jar包, Hibernate也用它来读写配置文件。

dom4j配置

  • 官网下载dom4j
  • 在项目中新建一个Folder用来添加dom4j
  • 在dom4j上点击鼠标右键找到Build Path加入到项目中

利用Dom4j读取XML文档

以我这篇博客【XML】XML基本结构以及XML-Schema约束的XML文档为例:

import java.util.List;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; public class HrReader { public void readXml(){
String file = "E:/workspace/eclipse/HelloWorld/src/test2/hr.xml";
//SAXReader类是读取XML文件的核心类,用于将XML解析后以“树”的形式保存在内存中
SAXReader reader = new SAXReader();
try {
Document document = reader.read(file);
Element root = document.getRootElement();//获取XML文档的根节点,即hr标签
List<Element> employees = root.elements("employee");//elements方法用于获取指定的标签集合
for(Element employee : employees){
Element name = employee.element("name");//element方法用于获取唯一的子节点对象
String empName = name.getText();//getText()方法用于获取标签文本
System.out.println(empName);
System.out.println(employee.elementText("age"));
System.out.println(employee.elementText("salary"));
Element department = employee.element("department");
System.out.println(department.element("dname").getText());
System.out.println(department.elementText("address"));
Attribute att = employee.attribute("no");
System.out.println(att.getText());
System.out.println("------");
}
} catch (DocumentException e) {
e.printStackTrace();
}
} public static void main(String[] args) {
HrReader reader = new HrReader();
reader.readXml();
}
}

利用Dom4j写入XML文档

import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer; import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; public class HrWriter { public void writeXml(){
String file = "E:/workspace/eclipse/HelloWorld/src/test2/hr.xml";//XML文件地址
SAXReader reader = new SAXReader();//SAXReader类是读取XML文件的核心类
try {
Document document = reader.read(file);//将XML解析后以“树”的形式保存在内存中
Element root = document.getRootElement();//获取XML文档的根节点,即hr标签
Element employee = root.addElement("employee");//加入一个员工
employee.addAttribute("no", "009");//设置员工属性
Element name = employee.addElement("name");//加入一个员工名称
name.setText("李四");//设置员工名称
employee.addElement("age").setText("34");//加入并设置员工的年龄
employee.addElement("salary").setText("6000");//加入并设置员工的薪水
Element department = employee.addElement("department");//加入员工所属部门
department.addElement("dname").setText("人事部");//加入并设置员工所属部门的名字
department.addElement("address").setText("XX大厦-B105");//加入并设置员工所属部门的地址
Writer writer = new OutputStreamWriter(new FileOutputStream(file), "UTF-8");//将文件输出流转化成writer对象
document.write(writer);//将内存中构建的DOM模型写入XML文件中
writer.close();//关闭输出流
} catch (Exception e) {
e.printStackTrace();//如果有异常则打印堆栈信息
}
} public static void main(String[] args){
HrWriter hrWriter = new HrWriter();//新建一个hrWriter对象
hrWriter.writeXml();//调用writeXml方法
}
}

写入之后的XML文档为:

<?xml version="1.0" encoding="UTF-8"?>
<!-- 人力资源管理系统 -->
<hr xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="hr.xsd">
<employee no="007">
<name>或无言</name>
<age>18</age>
<salary>20000</salary>
<department>
<dname>开发部</dname>
<address>XX大厦-B103</address>
</department>
</employee>
<employee no="008">
<name>张三</name>
<age>31</age>
<salary>30000</salary>
<department>
<dname>工程部</dname>
<address>XX大厦-B104</address>
</department>
</employee>
<employee no="009">
<name>李四</name>
<age>34</age>
<salary>6000</salary>
<department>
<dname>人事部</dname>
<address>XX大厦-B105</address>
</department>
</employee>
</hr>

总结

dom4j是一个很好的工具,当XML文档有大量数据需要处理时非常方便。

参考文献:

https://www.baidu.com/s?wd=dom4j&ie=UTF-8

上一篇:手机访问PC网站自动跳转到手机版


下一篇:xml文档解析