Skip to content

SAX(Simple API for XML)是一种基于事件驱动的XML解析技术,相比DOM解析器,它更适用于处理大型XML文件或者只需要获取部分数据的情况。

下面是一个简单的示例代码,演示了如何使用SAX解析器来读取XML文件:

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;

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

public class SAXParserExample {

    public static void main(String[] args) {
        try {
            // 创建SAXParser实例
            SAXParserFactory factory = SAXParserFactory.newInstance();
            SAXParser saxParser = factory.newSAXParser();

            // 创建自定义的Handler
            MyHandler handler = new MyHandler();

            // 解析XML文件
            File xmlFile = new File("path/to/your/xml/file.xml");
            saxParser.parse(xmlFile, handler);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    // 自定义的Handler类,继承DefaultHandler
    private static class MyHandler extends DefaultHandler {

        @Override
        public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
            // 处理元素开始标签
            System.out.println("Start Element: " + qName);
        }

        @Override
        public void endElement(String uri, String localName, String qName) throws SAXException {
            // 处理元素结束标签
            System.out.println("End Element: " + qName);
        }

        @Override
        public void characters(char[] ch, int start, int length) throws SAXException {
            // 处理元素内容
            String content = new String(ch, start, length).trim();
            if (!content.isEmpty()) {
                System.out.println("Element Content: " + content);
            }
        }
    }
}

你需要将代码中的path/to/your/xml/file.xml替换为你实际的XML文件路径。在自定义的Handler类中,你可以根据需要重写startElementendElementcharacters方法来处理不同的事件,例如获取元素名称、属性值或者元素内容等。