XML文件凭借结构清晰、可读性强的特点,在配置文件存储、跨平台数据交换等场景中十分常见,读写XML文件是开发者经常需要处理的基础操作。不同编程语言的XML读写实现逻辑存在差异,下面将分别展示Python和Java两种常用语言的读写案例。

Python读写XML文件案例
读取XML文件
Python内置的xml.etree.ElementTree模块可以方便地处理XML文件,以下代码实现了读取XML文件并打印所有节点内容的功能:
import xml.etree.ElementTree as ET
# 解析XML文件
tree = ET.parse('test.xml')
# 获取根节点
root = tree.getroot()
# 遍历所有子节点
for child in root:
print(f"节点名称:{child.tag},节点属性:{child.attrib}")
# 遍历子节点的子节点
for sub_child in child:
print(f" 子节点名称:{sub_child.tag},节点文本:{sub_child.text}")
写入XML文件
以下代码实现了创建新的XML结构并写入文件的操作:
import xml.etree.ElementTree as ET
# 创建根节点
root = ET.Element('users')
# 创建第一个用户节点
user1 = ET.SubElement(root, 'user', {'id': '1'})
name1 = ET.SubElement(user1, 'name')
name1.text = '张三'
age1 = ET.SubElement(user1, 'age')
age1.text = '25'
# 创建第二个用户节点
user2 = ET.SubElement(root, 'user', {'id': '2'})
name2 = ET.SubElement(user2, 'name')
name2.text = '李四'
age2 = ET.SubElement(user2, 'age')
age2.text = '28'
# 生成XML树并写入文件
tree = ET.ElementTree(root)
tree.write('output.xml', encoding='utf-8', xml_declaration=True)
Java读写XML文件案例
读取XML文件
Java可以使用DOM解析方式读取XML文件,以下代码实现了读取XML节点信息的功能:
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;
import java.io.File;
public class ReadXML {
public static void main(String[] args) {
try {
// 创建解析器工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
// 解析XML文件
Document document = builder.parse(new File("test.xml"));
// 获取根节点
Element root = document.getDocumentElement();
// 获取所有user节点
NodeList userNodes = root.getElementsByTagName("user");
for (int i = 0; i < userNodes.getLength(); i++) {
Node userNode = userNodes.item(i);
if (userNode.getNodeType() == Node.ELEMENT_NODE) {
Element userElement = (Element) userNode;
String id = userElement.getAttribute("id");
String name = userElement.getElementsByTagName("name").item(0).getTextContent();
String age = userElement.getElementsByTagName("age").item(0).getTextContent();
System.out.println("用户ID:" + id + ",姓名:" + name + ",年龄:" + age);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
写入XML文件
Java可以通过DOM方式创建XML结构并写入文件,代码如下:
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import java.io.File;
public class WriteXML {
public static void main(String[] args) {
try {
// 创建文档构建器
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
// 创建新文档
Document document = builder.newDocument();
// 创建根节点
Element root = document.createElement("users");
document.appendChild(root);
// 创建第一个用户节点
Element user1 = document.createElement("user");
user1.setAttribute("id", "1");
Element name1 = document.createElement("name");
name1.appendChild(document.createTextNode("张三"));
Element age1 = document.createElement("age");
age1.appendChild(document.createTextNode("25"));
user1.appendChild(name1);
user1.appendChild(age1);
root.appendChild(user1);
// 创建第二个用户节点
Element user2 = document.createElement("user");
user2.setAttribute("id", "2");
Element name2 = document.createElement("name");
name2.appendChild(document.createTextNode("李四"));
Element age2 = document.createElement("age");
age2.appendChild(document.createTextNode("28"));
user2.appendChild(name2);
user2.appendChild(age2);
root.appendChild(user2);
// 写入文件
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
DOMSource source = new DOMSource(document);
StreamResult result = new StreamResult(new File("output.xml"));
transformer.transform(source, result);
} catch (Exception e) {
e.printStackTrace();
}
}
}
读写XML的注意事项
- 读取XML时要注意文件路径的正确性,避免文件不存在导致的解析异常
- 写入XML时要指定正确的编码格式,防止中文内容出现乱码
- 操作XML节点时要注意空值判断,避免获取不存在的节点导致程序报错
- 如果XML文件结构复杂,可以选择适合的解析方式,小文件用DOM解析,大文件建议使用SAX解析减少内存占用