XML DOM 安装使用教程

一、XML DOM 简介

XML DOM(文档对象模型)是一种用于访问和操作 XML 文档的编程接口。它将 XML 文档表示为一棵树结构,可以通过编程语言动态读取、修改、添加和删除 XML 元素和属性。

支持 XML DOM 的语言包括 Java、JavaScript、Python、C# 等。


二、常见编程语言的支持

编程语言 XML DOM 操作库
Java javax.xml.parsers.*org.w3c.dom.*
Python xml.dom.minidomElementTree
JavaScript 浏览器内建 XML DOM 支持
C# System.Xml 命名空间

三、环境准备与安装

3.1 Java

Java 中无需安装额外库,JDK 已内置支持:

xml 复制代码
<dependency>
    <groupId>javax.xml</groupId>
    <artifactId>jaxp-api</artifactId>
</dependency>

3.2 Python

Python 自带 xml.dom.minidom 模块:

bash 复制代码
# 若使用第三方库 lxml,可用以下命令安装:
pip install lxml

四、Java 示例:读取 XML

java 复制代码
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.parse("example.xml");

NodeList names = doc.getElementsByTagName("name");
System.out.println(names.item(0).getTextContent());

五、Python 示例:读取 XML

python 复制代码
from xml.dom.minidom import parse

dom = parse("example.xml")
root = dom.documentElement

name = root.getElementsByTagName("name")[0].firstChild.data
print(name)

六、JavaScript 示例(浏览器环境)

html 复制代码
<script>
var xmlStr = `<person><name>小奇</name></person>`;
var parser = new DOMParser();
var xmlDoc = parser.parseFromString(xmlStr, "text/xml");

var name = xmlDoc.getElementsByTagName("name")[0].textContent;
console.log(name);
</script>

七、常见操作

7.1 遍历子节点(Java)

java 复制代码
NodeList list = root.getChildNodes();
for (int i = 0; i < list.getLength(); i++) {
    Node node = list.item(i);
    if (node.getNodeType() == Node.ELEMENT_NODE) {
        System.out.println(node.getNodeName());
    }
}

7.2 创建元素并写入 XML(Python)

python 复制代码
from xml.dom.minidom import Document

doc = Document()
root = doc.createElement('person')
doc.appendChild(root)

name = doc.createElement('name')
name.appendChild(doc.createTextNode('小奇'))
root.appendChild(name)

with open("new.xml", "w") as f:
    f.write(doc.toprettyxml(indent="  "))

八、常见问题

Q1: Java 报错"Cannot parse XML"?

  • 确认 XML 文件格式正确;
  • 检查路径是否正确;
  • 使用 try-catch 捕获异常查看详细信息。

Q2: DOM 操作效率低?

  • DOM 会将整个 XML 加载入内存,适合小文件;
  • 对于大文件建议使用 SAX 或 StAX 等事件驱动方式。

九、学习资源推荐


本文由"小奇Java面试"原创发布,转载请注明出处。

可以搜索【小奇JAVA面试】第一时间阅读,回复【资料】获取福利,回复【项目】获取项目源码,回复【简历模板】获取简历模板,回复【学习路线图】获取学习路线图。

相关推荐
暖木生晖几秒前
引入资源即针对于不同的屏幕尺寸,调用不同的css文件
前端·css·媒体查询
袁煦丞33 分钟前
DS file文件管家远程自由:cpolar内网穿透实验室第492个成功挑战
前端·程序员·远程工作
用户0137412843734 分钟前
九个鲜为人知却极具威力的 CSS 功能:提升前端开发体验的隐藏技巧
前端
永远不打烊38 分钟前
Window环境 WebRTC demo 运行
前端
风舞39 分钟前
一文搞定JS所有类型判断最佳实践
前端·javascript
coding随想39 分钟前
哈希值变化的魔法:深入解析HTML5 hashchange事件的奥秘与实战
前端
一树山茶1 小时前
uniapp在微信小程序中实现 SSE进行通信
前端·javascript
coding随想1 小时前
小程序中的pageshow与pagehide事件,HTML5中也有?揭秘浏览器往返缓存(BFCache)
前端
萌萌哒草头将军1 小时前
Rspack 1.5 版本更新速览!🚀🚀🚀
前端·javascript·vue.js
阿卡不卡1 小时前
基于多场景的通用单位转换功能实现
前端·javascript