导读:本期聚焦于小伙伴创作的《如何使用SAX方法读取XML文件?附完整示例代码》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何使用SAX方法读取XML文件?附完整示例代码》有用,将其分享出去将是对创作者最好的鼓励。

SAX(Simple API for XML)是一种基于事件驱动的XML解析技术,解析过程中会逐行读取XML内容,遇到元素开始、元素结束、文本内容等节点时触发对应的回调方法,不需要将整个XML文档加载到内存中,因此非常适合处理体积较大的XML文件。

如何使用SAX方法读取XML文件?附完整示例代码

SAX解析的核心组件

使用SAX解析XML主要需要用到以下几个核心类:

  • XMLReader:SAX解析的核心驱动类,负责读取XML文件并触发对应的事件
  • DefaultHandler:SAX提供的默认事件处理适配器类,我们可以继承它并重写需要的方法来实现自定义的解析逻辑
  • SAXParserFactory:用于创建SAX解析器的工厂类

需要重写的DefaultHandler方法

继承DefaultHandler之后,通常需要重写以下几个方法:

  • startDocument():文档开始解析时触发
  • endDocument():文档解析结束时触发
  • startElement(String uri, String localName, String qName, Attributes attributes):遇到元素开始标签时触发,qName是元素名称,attributes是元素的属性集合
  • endElement(String uri, String localName, String qName):遇到元素结束标签时触发
  • characters(char[] ch, int start, int length):遇到元素文本内容时触发

完整示例代码

1. 待解析的XML文件示例

假设我们有一个名为users.xml的文件,内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<users>
    <user id="1">
        <name>张三</name>
        <age>25</age>
        <email>zhangsan@ipipp.com</email>
    </user>
    <user id="2">
        <name>李四</name>
        <age>28</age>
        <email>lisi@ipipp.com</email>
    </user>
</users>

2. 自定义SAX解析处理器

我们创建一个继承DefaultHandler的类,实现自定义的解析逻辑:

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
import java.util.ArrayList;
import java.util.List;

public class UserHandler extends DefaultHandler {
    // 存储解析出的用户列表
    private List<User> userList = new ArrayList<>();
    // 当前解析的用户对象
    private User currentUser;
    // 当前解析的元素名称
    private String currentElement;

    // 文档开始解析时调用
    @Override
    public void startDocument() throws SAXException {
        System.out.println("开始解析XML文档");
    }

    // 文档解析结束时调用
    @Override
    public void endDocument() throws SAXException {
        System.out.println("XML文档解析结束");
    }

    // 遇到元素开始标签时调用
    @Override
    public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
        currentElement = qName;
        // 如果是user元素开始,创建新的User对象
        if ("user".equals(qName)) {
            currentUser = new User();
            // 获取id属性
            String id = attributes.getValue("id");
            currentUser.setId(Integer.parseInt(id));
        }
    }

    // 遇到元素结束标签时调用
    @Override
    public void endElement(String uri, String localName, String qName) throws SAXException {
        // 如果是user元素结束,将当前用户添加到列表
        if ("user".equals(qName)) {
            userList.add(currentUser);
            currentUser = null;
        }
        currentElement = null;
    }

    // 遇到元素文本内容时调用
    @Override
    public void characters(char[] ch, int start, int length) throws SAXException {
        if (currentElement == null || currentUser == null) {
            return;
        }
        String content = new String(ch, start, length).trim();
        if (content.length() == 0) {
            return;
        }
        // 根据当前元素名称赋值
        switch (currentElement) {
            case "name":
                currentUser.setName(content);
                break;
            case "age":
                currentUser.setAge(Integer.parseInt(content));
                break;
            case "email":
                currentUser.setEmail(content);
                break;
        }
    }

    // 获取解析后的用户列表
    public List<User> getUserList() {
        return userList;
    }

    // 内部用户实体类
    static class User {
        private int id;
        private String name;
        private int age;
        private String email;

        public void setId(int id) {
            this.id = id;
        }

        public void setName(String name) {
            this.name = name;
        }

        public void setAge(int age) {
            this.age = age;
        }

        public void setEmail(String email) {
            this.email = email;
        }

        @Override
        public String toString() {
            return "User{id=" + id + ", name='" + name + "', age=" + age + ", email='" + email + "'}";
        }
    }
}

3. 主程序调用解析逻辑

编写主程序来触发SAX解析流程:

import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import java.io.File;
import java.util.List;

public class SAXReadXMLDemo {
    public static void main(String[] args) {
        try {
            // 创建SAX解析器工厂
            SAXParserFactory factory = SAXParserFactory.newInstance();
            // 获取SAX解析器
            SAXParser saxParser = factory.newSAXParser();
            // 创建自定义处理器
            UserHandler handler = new UserHandler();
            // 解析XML文件,传入文件和处理器
            saxParser.parse(new File("users.xml"), handler);
            // 获取解析结果并输出
            List<UserHandler.User> userList = handler.getUserList();
            for (UserHandler.User user : userList) {
                System.out.println(user);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

代码运行结果

执行上述主程序后,控制台会输出以下内容:

开始解析XML文档
XML文档解析结束
User{id=1, name='张三', age=25, email='zhangsan@ipipp.com'}
User{id=2, name='李四', age=28, email='lisi@ipipp.com'}

SAX解析的优缺点

SAX解析的主要优点:

  • 内存占用低,不需要加载整个XML文档到内存,适合大文件解析
  • 解析速度快,逐行读取处理,没有额外的内存开销

主要缺点:

  • 只能顺序读取XML内容,无法随机访问某个节点
  • 没有将XML结构转化为树形对象,如果需要多次使用解析后的数据,需要自己存储
  • 编写回调逻辑相对复杂,不如DOM解析直观

SAXXMLJavaXMLReader修改时间:2026-06-23 13:30:38

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。