zoukankan      html  css  js  c++  java
  • 【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

  • 相关阅读:
    7-1 N个数求和
    3662. 最大上升子序列和
    树状数组
    堆优化Dijkstra java模板
    皮亚诺曲线距离
    最长公共子序列(计数问题)
    最小路径覆盖
    极角排序
    2619. 询问
    Hessian矩阵与局部极小值
  • 原文地址:https://www.cnblogs.com/huowuyan/p/11203846.html
Copyright © 2011-2022 走看看