最常用方法是使用xml.etree.ElementTree模块遍历XML节点和属性。首先通过ET.parse()加载文件并获取根节点,接着可用递归函数或iter()方法遍历所有节点,打印标签、属性和文本内容,还可将信息存入列表统一处理,适用于数据提取等场景,注意处理命名空间问题。

Python 中遍历 XML 所有节点和属性,最常用的方法是使用内置的 xml.etree.ElementTree 模块。它轻量、易用,适合处理大多数 XML 数据。下面介绍如何完整遍历 XML 文件中的所有节点及其属性。
使用 ElementTree.parse() 读取 XML 文件,获取根节点,然后从根开始遍历。
import xml.etree.ElementTree as ET
<p>tree = ET.parse('example.xml') # 替换为你的文件名
root = tree.getroot() # 获取根元素</p>通过递归函数访问每个节点,包括嵌套的子节点。
def traverse_xml(element):
# 打印当前节点标签名
print(f"Tag: {element.tag}")
<pre class='brush:php;toolbar:false;'># 打印当前节点的所有属性
if element.attrib:
print(f" Attributes: {element.attrib}")
# 打印文本内容(去除空白)
if element.text and element.text.strip():
print(f" Text: {element.text.strip()}")
# 递归处理所有子节点
for child in element:
traverse_xml(child)traverse_xml(root)
立即学习“Python免费学习笔记(深入)”;
如果不需要递归结构,可以直接用 element.iter() 遍历所有后代节点(深度优先)。
for elem in root.iter():
print(f"Tag: {elem.tag}")
if elem.attrib:
print(f" Attributes: {elem.attrib}")
if elem.text and elem.text.strip():
print(f" Text: {elem.text.strip()}")
你可以进一步提取某个属性值,或者统一收集所有节点的属性用于分析。
# 收集所有节点的标签和属性到列表
nodes_info = []
for elem in root.iter():
node_data = {
'tag': elem.tag,
'attributes': elem.attrib,
'text': elem.text.strip() if elem.text else None
}
nodes_info.append(node_data)
<h1>打印结果示例</h1><p>for node in nodes_info:
print(node)</p>基本上就这些。用 ElementTree 就能高效完成 XML 的全节点与属性遍历,适合配置文件解析、数据提取等场景。注意处理好命名空间(如果有),否则标签可能显示为 {namespace}tagname 形式。
以上就是Python怎么遍历XML所有节点和属性_Python遍历XML所有节点和属性方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号