Python如何解析xml文件? ElementTree库使用教程与实例

ElementTree是Python处理XML的常用库,支持从文件或字符串加载数据,通过find、findall和iter方法遍历元素,可修改内容并保存,适用于解析配置文件和接口数据。

Python解析XML文件最常用的方式是使用内置的xml.etree.ElementTree库(简称ElementTree)。它轻量、易用,适合处理结构清晰的XML数据。本文将介绍ElementTree的基本用法,并通过实际例子帮助你快速掌握。

1. 加载XML数据

ElementTree支持从字符串或文件加载XML。使用ET.parse()读取文件,或ET.fromstring()解析字符串。

  • 从文件加载:返回ElementTree对象,需调用.getroot()获取根元素
  • 从字符串加载:直接返回根元素(Element对象)

示例XML文件(data.xml):



  
    Python入门
    张三
    50.0
  
  
    数据分析实战
    李四
    68.5
  

代码加载方式:

import xml.etree.ElementTree as ET

从文件读取

tree = ET.parse('data.xml') root = tree.getroot()

或从字符串读取

xml_str = """...""" root = ET.fromstring(xml_str)

2. 遍历与查找元素

Element对象提供多种方法访问子元素和属性。常用方法包括.find().findall().iter()

  • .find(tag):返回第一个匹配的子元素
  • .findall(tag):返回所有匹配的子元素列表
  • .iter(tag):遍历整个树中所有指定标签的元素
  • .attrib:获取元素属性字典
  • .text:获取元素文本内容

示例:提取所有书名和作者

for book in root.findall('book'):
    title = book.find('title').text
    author = book.find('author').text
    book_id = book.get('id')  # 获取属性
    print(f"ID: {book_id}, 书名: {title}, 作者: {author}")

3. 修改与保存XML

你可以动态修改元素内容、添加属性或新节点,并将结果写回文件。

示例:给每本书加一个分类标签

for book in root.findall('book'):
    category = ET.SubElement(book, 'category')
    if 'Python' in book.find('title').text:
        category.text = '编程'
    else:
        category.text = '数据科学'

保存到新文件

tree.write('updated_data.xml', encoding='utf-8', xml_declaration=True)

生成的XML会包含新增的节点。

4. 处理复杂结构与命名空间

当XML包含命名空间时,需在标签前加上命名空间前缀。

例如,带有命名空间的XML:


  内容

查找时需完整写法:

namespace = {'ns': 'http://example.com/ns'}
item = root.find('ns:item', namespace)
if item is not None:
    print(item.text)

基本上就这些。ElementTree足够应对大多数日常XML处理需求,不复杂但容易忽略细节,比如.getroot().findall()的作用范围。熟练掌握后,读取配置文件、解析接口返回数据都会变得轻松。