Java解析XML:常用方法详解
7 浏览量
更新于2024-09-02
收藏 33KB PDF 举报
本文主要总结了Java中解析XML文件的常用方法,包括DOM、SAX和StAX等解析器的使用,并提供了一个简单的XML文件示例。
在Java中,解析XML文件是常见的任务,用于读取和处理XML文档的数据。以下是Java解析XML的三种主要方式:
1. DOM(Document Object Model)解析器:
DOM解析器将整个XML文件加载到内存中,创建一个树形结构,称为DOM树。这样可以方便地通过节点遍历和操作XML文档。以下是一个使用DOM解析器的基本示例:
```java
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
public class DOMParserExample {
public static void main(String[] args) {
try {
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse("books.xml");
doc.getDocumentElement().normalize();
NodeList nodeList = doc.getElementsByTagName("book");
for (int i = 0; i < nodeList.getLength(); i++) {
Node node = nodeList.item(i);
if (node.getNodeType() == Node.ELEMENT_NODE) {
Element element = (Element) node;
// 获取并打印元素属性
System.out.println("Category: " + element.getAttribute("category"));
// 遍历子元素
// ...
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
```
2. SAX(Simple API for XML)解析器:
与DOM不同,SAX是一种事件驱动的解析器,它不会一次性加载整个XML文档,而是逐行扫描。每当遇到开始标签、结束标签、文本等事件时,会触发相应的回调函数。这种方式适用于大文件或内存有限的情况。
```java
import org.xml.sax.helpers.DefaultHandler;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
public class SAXParserExample extends DefaultHandler {
@Override
public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
if ("book".equals(qName)) {
String category = attributes.getValue("category");
System.out.println("Category: " + category);
}
}
public static void main(String[] args) {
try {
SAXParserFactory spf = SAXParserFactory.newInstance();
SAXParser saxParser = spf.newSAXParser();
saxParser.parse("books.xml", new SAXParserExample());
} catch (Exception e) {
e.printStackTrace();
}
}
}
```
3. StAX(Streaming API for XML)解析器:
StAX是另一种流式解析方法,它允许应用程序通过调用`next()`方法来逐个处理XML事件。这种方式提供了更细粒度的控制,同时避免了DOM解析器的内存消耗。
```java
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamReader;
import java.io.FileInputStream;
import java.io.InputStream;
public class StAXParserExample {
public static void main(String[] args) {
try {
XMLInputFactory xif = XMLInputFactory.newFactory();
InputStream in = new FileInputStream("books.xml");
XMLStreamReader xsr = xif.createXMLStreamReader(in);
while (xsr.hasNext()) {
int event = xsr.next();
if (event == XMLStreamReader.START_ELEMENT && "book".equals(xsr.getLocalName())) {
String category = xsr.getAttributeValue(null, "category");
System.out.println("Category: " + category);
}
}
xsr.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
```
以上三种方法各有优缺点:DOM解析器易于使用但占用内存较多;SAX解析器节省内存但编程相对复杂;StAX解析器则提供了更好的性能和灵活性。根据具体需求,可以选择适合的解析方式。在处理大型XML文件或内存受限的环境中,SAX和StAX通常更受欢迎,而DOM则适合小规模或对性能要求不高的应用。
378 浏览量
316 浏览量
173 浏览量
111 浏览量
445 浏览量
134 浏览量
2012-07-25 上传
weixin_38536397
- 粉丝: 7
- 资源: 961
最新资源
- hello-webauthn
- 钢琴3D模型素材
- spec-prod:GitHub Action构建ReSpecBikeshed规范,验证输出并发布到GitHub页面或W3C
- xlsrange:从行号和列号生成一个excel范围-matlab开发
- C#使用Redis内存数据库
- XX公司组织架构说明书DOC
- 雨棚3d模型设计
- multiple-theme-switcher-website
- 电力及公用事业行业月报月全社会用电量同比增长长江三峡来水情况改善明显-19页.pdf.zip
- Conway's Game of Life:基于 Conway 的四个规则生成细胞群并研究其行为的接口。-matlab开发
- gulp:自己gulp练习
- 带反射面板的远距离光束中断传感器-项目开发
- 现代企业员工培训与开发的实施模型DOC
- lab-bucket-list
- 苹果专卖店三维模型设计
- jshelp:Javascript 帮助