Java XML 解析方式

XML(可扩展标记语言)是一种用于存储和传输结构化数据的标记语言。在Java中,我们可以使用不同的方式解析XML文档,以读取和操作其中的数据。本文将介绍常用的Java XML解析方式,并提供相应的代码示例。

DOM 解析方式

DOM(文档对象模型)解析方式将整个XML文档加载到内存中,并将其表示为一个树形结构(DOM树)。通过遍历DOM树,我们可以访问和操作XML文档的各个元素和属性。

在Java中,我们可以使用javax.xml.parsers.DocumentBuilder类来进行DOM解析。下面是一个简单的示例:

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class DomParserExample {

    public static void main(String[] args) {
        try {
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            DocumentBuilder builder = factory.newDocumentBuilder();
            Document document = builder.parse("example.xml");

            Element root = document.getDocumentElement();
            NodeList nodeList = root.getChildNodes();

            for (int i = 0; i < nodeList.getLength(); i++) {
                Node node = nodeList.item(i);
                if (node.getNodeType() == Node.ELEMENT_NODE) {
                    Element element = (Element) node;
                    String name = element.getTagName();
                    String value = element.getTextContent();
                    System.out.println(name + ": " + value);
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

上面的代码通过DOM解析方式读取了名为example.xml的XML文档,并遍历了其中的元素和属性。

SAX 解析方式

SAX(简单API for XML)解析方式采用事件驱动的方式解析XML文档。当解析器遇到XML文档中的某个元素、属性或文本时,它会触发相应的事件,我们可以通过注册事件处理器来捕获这些事件。

在Java中,我们可以使用org.xml.sax.helpers.DefaultHandler类来进行SAX解析。下面是一个简单的示例:

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;

public class SaxParserExample {

    public static void main(String[] args) {
        try {
            SAXParserFactory factory = SAXParserFactory.newInstance();
            SAXParser parser = factory.newSAXParser();

            DefaultHandler handler = new DefaultHandler() {
                boolean nameFlag = false;

                public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
                    if (qName.equalsIgnoreCase("name")) {
                        nameFlag = true;
                    }
                }

                public void characters(char[] ch, int start, int length) throws SAXException {
                    if (nameFlag) {
                        System.out.println("Name: " + new String(ch, start, length));
                        nameFlag = false;
                    }
                }
            };

            parser.parse("example.xml", handler);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

上面的代码通过SAX解析方式读取了名为example.xml的XML文档,并捕获了其中的name元素。

XPath 解析方式

XPath是一种用于在XML文档中定位元素的语言。它提供了一种简洁的方式来选择和提取XML文档中的数据。

在Java中,我们可以使用javax.xml.xpath.XPath类来进行XPath解析。下面是一个简单的示例:

import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;

public class XPathParserExample {

    public static void main(String[] args) {
        try {
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            DocumentBuilder builder = factory.newDocumentBuilder();
            Document document = builder.parse("example.xml");

            XPathFactory xPathFactory = XPathFactory.newInstance();
            XPath xPath = xPathFactory.newXPath();

            String expression = "/root/element";
            NodeList nodeList = (NodeList) xPath.compile(expression).evaluate(document, XPathConstants.NODESET);

            for (int i = 0; i < nodeList.getLength(); i++) {
                System.out.println("Element: " + nodeList.item(i).getTextContent());
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}