本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名原文链接~~~

XML解析之Dom4j

微信搜索 zze_coding 或扫描 👉 二维码关注我的微信公众号获取更多资源推送:


介绍

XML 解析方式有很多种,但是常用的有两种,如下:

Dom

Document Object Model:把整个 XML 读到内存中,形成树状结构。整个文档为 Document 对象,属性为 Attribute 对象,元素节点为 Element 对象,文本也可以称之为 Text 对象,以上所有对象都可以称之为 Node 节点。如果 XML 特别大,那么会造成内存溢出。可以利用它对 XML 文档进行增删操作。

Sax

Simple API for XML:基于事件驱动,读取一行,解析一行。不会造成内存溢出。只能查询,不可以进行增删操作。
下面就是使用 Sax 方式解析的示例。

依赖及文档下载

使用示例

有如下测试 XML 文件:

<!-- student.xml -->
<?xml version="1.0" encoding="UTF-8" ?>
<students>
    <student>
        <name id="1">杨幂</name>
        <age>32</age>
    </student>
    <student>
        <name>郭德纲</name>
        <age>18</age>
    </student>
</students>

解析:

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.junit.Test;

import java.util.List;

public class XMLParseTest {
    /**
     * Element 方式解析
     */
    @Test
    public void test1() {
        try {
            // 创建 SAX 读取对象
            SAXReader saxReader = new SAXReader();
            // 指定读取源
            Document document = saxReader.read(this.getClass().getClassLoader().getResourceAsStream("com/zze/xml/student.xml"));
            // 获取根元素
            Element rootElement = document.getRootElement();
            List<Element> studentElements = rootElement.elements("student");
            for (Element studentElement : studentElements) {
                String name = studentElement.element("name").getText();
                Integer age = Integer.parseInt(studentElement.element("age").getText());
                System.out.println(String.format("name:%s", name));
                System.out.println(String.format("age:%s", age));
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * XPath 方式解析
     * 要使用 XPath ,需要添加 jar 支持:jaxen-1.1-beta-6.jar
     */
    @Test
    public void test2() {
        Document document = null;
        try {
            SAXReader saxReader = new SAXReader();
            document = saxReader.read(this.getClass().getClassLoader().getResourceAsStream("com/zze/xml/student.xml"));
            Element rootElement = document.getRootElement();
            // 获取文档中所有 name 节点
            List<Element> nameElements = rootElement.selectNodes("//name");
            for (Element nameElement : nameElements) {
                System.out.println(nameElement.attribute("id") != null ? nameElement.attribute("id").getText() : "");
                System.out.println(nameElement.getText());
            }
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }
}
# Java 杂项  

如果这篇文章对您有帮助,可点击下方链接分享给你的朋友们😋,如果遇到问题欢迎评论、留言~~~😇

评论

公众号:zze_coding

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×