0

0

Python如何将XML转换为字典列表

月夜之吻

月夜之吻

发布时间:2026-01-01 08:45:55

|

474人浏览过

|

来源于php中文网

原创

xmltodict处理同名节点需设force_list参数,否则默认合并为字典;属性转为@key,文本为#text,嵌套结构需手动提取;不规范XML应先用ElementTree校验。

python如何将xml转换为字典列表

用 xmltodict 处理单层同名节点最直接

当 XML 中存在多个同级同名标签(比如 ),xmltodict.parse() 默认会把它们合并成一个字典,而不是列表——这是最容易踩的坑。必须显式传入 force_list 参数才能保留为列表结构。

常见错误现象:

{'root': {'item': {'name': 'a'}}}
(只留了一个)而非
{'root': {'item': [{'name': 'a'}, {'name': 'b'}]}}

  • 对所有 item 标签强制转为列表:force_list=['item']
  • 若想统一处理所有重复标签,可设 force_list=True,但要注意这会让所有标签都变成列表(包括只出现一次的),后续取值需写 [0]
  • 配合 process_namespaces=False(默认值)避免命名空间干扰,除非你明确需要解析带 xmlns 的 XML

嵌套结构里 list 和 dict 混用要手动 flatten

xmltodict 不会自动“扁平化”路径,比如 A 解析后是

{'data': {'items': {'item': {'name': 'A'}}}}
,而你想要的是 [{'name': 'A'}]。这时候不能只靠参数,得自己提取路径。

  • 先用 xmltodict.parse(xml_str, force_list=['item']) 得到嵌套结构
  • 再用字典键路径访问:例如 result['data']['items']['item'] —— 注意这里已经是列表(因为加了 force_list
  • 如果不确定某层是否存在,用 .get('items', {}).get('item', []) 避免 KeyError

遇到属性(@attr)和文本(#text)要小心类型混杂

XML 中的属性(如 abc)会被 xmltodict 转成 {'@id': '123', '#text': 'abc'}。如果你只需要纯内容,这些键名会干扰字段一致性。

讯飞智作-讯飞配音
讯飞智作-讯飞配音

讯飞智作是一款集AI配音、虚拟人视频生成、PPT生成视频、虚拟人定制等多功能的AI音视频生产平台。已广泛应用于媒体、教育、短视频等领域。

下载

立即学习Python免费学习笔记(深入)”;

  • 遍历列表时逐个清理:{k[1:]: v for k, v in item.items() if k.startswith('@')} 提取属性,或过滤掉 @#text
  • 若文本是唯一内容且无属性,可用 item.get('#text', item) 回退取值
  • 不要依赖 str(item)json.dumps 直接输出——#text 会导致字段名不统一

不用第三方库?标准库 xml.etree.ElementTree 更可控但更啰嗦

如果项目禁用外部依赖,xml.etree.ElementTree 是唯一选择,但它不自动生成字典,得手写递归逻辑。好处是能精确控制每个节点怎么转,坏处是容易漏掉属性、文本、命名空间等边缘情况。

  • elem.attrib 取属性,elem.text.strip() 取文本内容
  • 子节点用 list(elem) 遍历,对每个子节点递归调用转换函数
  • 判断是否为同名多节点:先收集所有 elem.findall('item'),再逐个转字典,最后汇总成列表
import xml.etree.ElementTree as ET

def elem_to_dict(elem): result = {k: v for k, v in elem.attrib.items()} if elem.text and elem.text.strip(): result['#text'] = elem.text.strip() for child in elem: child_data = elem_to_dict(child) if child.tag not in result: result[child.tag] = child_data else:

已存在,转为列表

        if not isinstance(result[child.tag], list):
            result[child.tag] = [result[child.tag]]
        result[child.tag].append(child_data)
return result

root = ET.fromstring(xml_str) data = {root.tag: elem_to_dict(root)}

真正麻烦的不是转换本身,而是 XML 源数据是否规范——有没有混用属性和文本、有没有缺闭合标签、有没有非法字符。建议先用 xml.etree.ElementTree.parse() 尝试加载,捕获 ParseError,比硬转字典更早发现问题。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

716

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

626

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

739

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1236

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

575

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

699

2023.08.11

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 2.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号