Python处理XML主要用xml.etree.ElementTree和lxml;前者是标准库,轻量简单但功能基础,适合基本操作;后者功能强大,支持XPath、XSLT等高级特性,性能更好但需安装;解析、遍历、查找、修改操作类似,ElementTree适用于简单场景,lxml适合复杂需求。

Python处理XML文件主要有两种常用方法:使用内置的xml.etree.ElementTree模块和第三方库lxml。它们都能解析、创建和修改XML数据,但在功能和性能上略有不同。
这是Python自带的XML处理模块,适合大多数基本操作,无需额外安装依赖。
优点:轻量、简单、标准库自带
缺点:功能较基础,不支持XPath高级查询
常见操作示例:
立即学习“Python免费学习笔记(深入)”;
import xml.etree.ElementTree as ET
tree = ET.parse('example.xml') # 解析文件
root = tree.getroot()for child in root:
print(child.tag, child.attrib)for elem in root.iter('tag_name'):
print(elem.text)root.find('tag').text = 'new value'
tree.write('output.xml')lxml是功能更强大的XML处理库,基于libxml2,支持XPath、XSLT、命名空间等高级特性。
优点:速度快、功能丰富、支持XPath 1.0
缺点:需要安装:pip install lxml
常见操作示例:
立即学习“Python免费学习笔记(深入)”;
from lxml import etree
tree = etree.parse('example.xml')
root = tree.getroot()for elem in root.xpath('//book[@category="fiction"]'):
print(elem.get('id'), elem.find('title').text)from lxml.cssselect import CSSSelector
sel = CSSSelector('book > title')
results = sel(root)print(etree.tostring(root, pretty_print=True, encoding='unicode'))
基本上就这些。如果只是读写简单配置文件,用ElementTree足够;若涉及复杂查询、大量数据或需XPath支持,推荐lxml。两者语法相似,切换成本不高。
以上就是python操作xml的两种方法的详细内容,更多请关注php中文网其它相关文章!
python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号