python xml处理
1|0一、xml.etree.ElementTree(以下简称ET)
Python标准库中,提供了ET的两种实现。一个是纯Python实现的xml.etree.ElementTree,另一个是速度更快的C语言实现xml.etree.cElementTree。请记住始终使用C语言实现,因为它的速度要快很多,而且内存消耗也要少很多。如果你所使用的Python版本中没有cElementTree所需的加速模块,你可以这样导入模块:
如果某个API存在不同的实现,上面是常见的导入方式。当然,很可能你直接导入第一个模块时,并不会出现问题。请注意,自Python 3.3之后,就不用采用上面的导入方法,因为ElemenTree模块会自动优先使用C加速器,如果不存在C实现,则会使用Python实现。因此,使用Python 3.3+的朋友,只需要import xml.etree.ElementTree即可。
以country.xml为例,内容如下:
1|11.1解析
1.1.1调用 parse() 方法,返回解析树
本质上和方法三相同,parse() 源码如下:
1.1.2 调用 from_string() ,返回解析树的根元素
1.1.3 调用 ElementTree模块的 ElementTree(self, element=None, file=None)类 # 这里的element作为根节点
1|21.2遍历
1.2.1简单遍历
可以通过下标的方式直接访问节点
1.2.2ElementTree提供的方法
- find(match) # 查找第一个匹配的子元素, match可以时tag或是xpaht路径
- findall(match) # 返回所有匹配的子元素列表
- findtext(match, default=None) #
- iter(tag=None) # 以当前元素为根节点 创建树迭代器,如果tag不为None,则以tag进行过滤
- iterfind(match) #
例子:
---
1|31.3 修改xml结构
1.3.1 属性相关
---
小结: 关于class xml.etree.ElementTree.``Element 属性相关
- attrib # 为包含元素属性的字典
- keys() # 返回元素属性名称列表
- items() # 返回(name,value)列表
- get(key, default=None) # 获取属性
- set(key, value) # 跟新/添加 属性
- del xxx.attrib[key] # 删除对应的属性
1.3.2节点/元素 相关
删除子元素remove()
添加子元素
添加子元素方法总结:
- append(subelement)
- extend(subelements)
- insert(index, element)
1|41.4创建xml文档
想创建root Element,然后创建SubElement,最后将root element传入ElementTree(element),创建tree,调用tree.write()方法写入文件
对于创建元素的3个方法: 使用ET.Element、Element对象的makeelement()方法以及ET.SubElement
效果:
由于原生保存的XML时默认无缩进,如果想要设置缩进的话, 需要修改保存方式
2|0二、lxml
2|12.1 Element 对象
2.1.1 工厂函数
在 XML或HTML 中每一处尖括号代表着一个标签或者元素, lxml 库为了方便操作, 封装了Element
类, 通过Element
对象可以很方便地操作 XML 的元素创建 Element
对象
添加 SubElement
对象, 组成有层级关系的 Elements
将 Elements 序列化为 XML 树
打印结果
没有子元素时, lxml 自动生成单标签
这样我们直接通过 lxml 库创建了一个 XML 文档
2.1.2 列表接口
每一个 Element 对象相当于一个列表容器, 其内容为直接子元素, 操作方法与内置列表很相似
2.1.2.1 索引
结果为首个添加的子元素
2.1.2.2 切片
切片的结果为内置列表
2.1.2.3 列表方法
在 root 起始位置添加了 child_0, 随后删除了 child_3, 通过 extend 在末尾补回 child_3
2.1.2.4 遍历
Element 对象与列表有一个细小的差别, Element 列表成员之间赋值, lxml 会删除赋值元素
最后一个元素的位置被删除了, 这么做是避免修改其中的一个元素, 另一个元素也会相应被修改
2.1.3 元素关系
父元素与相邻元素
2.1.4 字典接口
在 XML 或 HTML 中每一个标签都有属性, Element
类通过字典接口支持属性操作
创建带有属性的Element
对象
注意class
是 Python 关键字, 因此无法使用class="main"
按名称传参,而要用字典的方式
2.1.4.1 访问属性
与字典不同, 无法通过 root["name"]
访问和设置属性值, Element 的魔法方法 __getitem__
不支持字符串索引
2.1.4.2 设置属性
2.1.4.3 遍历属性
除了 items()
, root 与字典一样还支持 keys()
和values()
2.1.4.4 获取属性字典
借助于property
类, Element
对象的attrib
属性可视为字典对象
对 Element 元素属性的修改会映射到 attrib 属性, 反之亦然
2.1.4.5 操作属性字典
root.attrib
比root
本身更接近字典
2.1.5添加文本内容
如果将Element
对象看做元素节点, 那么其包含的文本就可看做文本节点, 在 lxml 包中Element
对象可以添加文本内容
创建包含文本内容的Element
对象
由于包含文本内容, root 变为双标签
在 XML 文档中, 文本内容只能包含于双标签内, 而 HTML 则不同, 文本内容可位于不同的标签之间, 所以Element
对象新增了tail
属性, 可在Element 末尾新增文本内容
在序列化 Element 对象时, 可以忽略末尾文本, 也可以仅输出文本内容
2|22.2 xpath
2.2.1 xpath 提取文本节点
与 text() 不同, 功能函数 string() 表示递归提取元素的文本内容, 并将它们连接成一个文本
创建 XML 示例
对比 text() 与 string()
使用 html 调用 xpath 表示从 html 节点开始解析
string() 中可以使用参数限制递归查找的范围, 仅寻找 html 下所有 span 元素的文本节点
这里 span 元素末尾的文本内容 “SPAN_2” 被分给了 body 元素
如果要经常使用某一个 XPath 表达式, 可以将解析规则保存到变量
在 lxml 包中, XPath 解析的结果通常为列表
对于lxml.etree._ElementUnicodeResult
这个类无需感到陌生, 因为它直接继承了str
, 并新增了一些内容
2.2.2XPath 提取属性节点
创建 HTML 示例
@*
表示匹配所有属性节点, 对比一下几种提取方法
提取属性节点和文本节点的结果类型是一样的, 都是继承了内置字符串并新增了一些方法
__EOF__

本文链接:https://www.cnblogs.com/dongye95/p/13974466.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!