先修改元素内容再改属性,使用ElementTree解析XML,通过find或findall定位元素,修改.text属性更改文本,用.set()或.attrib操作属性,最后write保存。

使用Python修改XML文件中的元素内容与属性
在Python中处理和修改XML文件,最常用的方式是使用内置的 xml.etree.ElementTree 模块。它提供了简单直观的API来读取、修改和保存XML数据。下面详细介绍如何修改XML元素的内容(文本)和属性值。
1. 修改XML元素的文本内容
要修改某个XML元素的文本内容,先通过标签名或路径查找该元素,然后直接赋值给其 .text 属性。
假设有一个名为 example.xml 的文件:
立即学习“Python免费学习笔记(深入)”;
现在我们想把第一个
tree = ET.parse('example.xml')
root = tree.getroot()
找到第一个 person 下的 name 元素
name_element = root.find('person/name')
if name_element is not None:
name_element.text = 'Anna'
保存回文件
tree.write('example.xml', encoding='utf-8', xml_declaration=True)
2. 修改XML元素的属性
修改元素属性也很简单,通过元素的 .set() 方法或直接操作 .attrib 字典即可。
例如,将第一个 person 元素的 id 属性改为 "101":
person = root.find('person')if person is not None:
person.set('id', '101')
如果你想删除某个属性,可以直接从 .attrib 中 pop 或 del:
# 删除 age 属性(如果存在)if 'age' in person.attrib:
del person.attrib['age']
3. 查找并批量修改多个元素
使用 .findall() 可以获取所有匹配的子元素,适合批量处理。
比如将所有
current_age = int(age_elem.text)
age_elem.text = str(current_age + 1)
其中 .//age 是XPath语法,表示查找所有层级下的 age 元素。
4. 添加新属性或创建新元素
虽然问题重点是“修改”,但实际中常伴随添加操作。例如为每个 person 添加一个 updated 属性:
for person in root.findall('person'):person.set('updated', 'true')
或者在某个元素内追加新标签:
name_elem = root.find('person/name')email = ET.SubElement(name_elem, 'email')
email.text = 'anna@example.com'
基本上就这些。只要掌握 find、findall、.text、.set() 和 write() 这几个核心方法,就能灵活地修改XML内容。注意每次修改后调用 tree.write() 才能持久化保存。










