
在处理从api或其他数据源获取的复杂数据时,我们经常会遇到嵌套的字典和列表结构。理解如何有效地从这些结构中提取和转换所需信息是python数据处理的关键技能。本教程将以一个典型的场景为例,演示如何将一个包含多层嵌套的字典数据,转换为一个更易于访问和使用的新字典。
假设我们从经纪商的API获取了以下数据,其类型为Python字典:
my_dict = {
'1': [
{'exch': 'NFO', 'token': '43214', 'tsym': 'NIFTY07DEC23C20700', 'weekly': 'W1', 'dname': 'NIFTY 07DEC23 20700 CE ', 'instname': 'OPTIDX', 'pp': '2', 'ls': '50', 'ti': '0.05', 'optt': 'CE'},
{'exch': 'NFO', 'token': '43218', 'tsym': 'NIFTY07DEC23P20700', 'weekly': 'W1', 'dname': 'NIFTY 07DEC23 20700 PE ', 'instname': 'OPTIDX', 'pp': '2', 'ls': '50', 'ti': '0.05', 'optt': 'PE'},
{'exch': 'NFO', 'token': '43206', 'tsym': 'NIFTY07DEC23C20600', 'weekly': 'W1', 'dname': 'NIFTY 07DEC23 20600 CE ', 'instname': 'OPTIDX', 'pp': '2', 'ls': '50', 'ti': '0.05', 'optt': 'CE'},
{'exch': 'NFO', 'token': '43207', 'tsym': 'NIFTY07DEC23P20600', 'weekly': 'W1', 'dname': 'NIFTY 07DEC23 20600 PE ', 'instname': 'OPTIDX', 'pp': '2', 'ls': '50', 'ti': '0.05', 'optt': 'PE'}
]
}这个my_dict的结构特点是:
我们的目标是从上述复杂结构中,提取每个内层字典的 'token' 和 'tsym' 字段,并构建一个新的字典。在这个新字典中,'token' 的值将作为新字典的键,而 'tsym' 的值将作为新字典的值。
期望的输出格式如下:
立即学习“Python免费学习笔记(深入)”;
{'43214': 'NIFTY07DEC23C20700',
'43218': 'NIFTY07DEC23P20700',
'43206': 'NIFTY07DEC23C20600',
'43207': 'NIFTY07DEC23P20600'}Python的字典推导式(Dictionary Comprehension)提供了一种简洁而高效的方式来创建字典。它允许我们通过遍历一个可迭代对象,并根据每个元素生成键值对来构建新字典。这正是解决我们当前问题的理想工具。
解决方案代码:
dct = {d['token']: d['tsym'] for d in my_dict['1']}代码解析:
完整示例:
my_dict = {
'1': [
{'exch': 'NFO', 'token': '43214', 'tsym': 'NIFTY07DEC23C20700', 'weekly': 'W1', 'dname': 'NIFTY 07DEC23 20700 CE ', 'instname': 'OPTIDX', 'pp': '2', 'ls': '50', 'ti': '0.05', 'optt': 'CE'},
{'exch': 'NFO', 'token': '43218', 'tsym': 'NIFTY07DEC23P20700', 'weekly': 'W1', 'dname': 'NIFTY 07DEC23 20700 PE ', 'instname': 'OPTIDX', 'pp': '2', 'ls': '50', 'ti': '0.05', 'optt': 'PE'},
{'exch': 'NFO', 'token': '43206', 'tsym': 'NIFTY07DEC23C20600', 'weekly': 'W1', 'dname': 'NIFTY 07DEC23 20600 CE ', 'instname': 'OPTIDX', 'pp': '2', 'ls': '50', 'ti': '0.05', 'optt': 'CE'},
{'exch': 'NFO', 'token': '43207', 'tsym': 'NIFTY07DEC23P20600', 'weekly': 'W1', 'dname': 'NIFTY 07DEC23 20600 PE ', 'instname': 'OPTIDX', 'pp': '2', 'ls': '50', 'ti': '0.05', 'optt': 'PE'}
]
}
# 使用字典推导式进行转换
dct = {d['token']: d['tsym'] for d in my_dict['1']}
print(dct)输出结果:
{'43214': 'NIFTY07DEC23C20700', '43218': 'NIFTY07DEC23P20700', '43206': 'NIFTY07DEC23C20600', '43207': 'NIFTY07DEC23P20600'}dct = {d.get('token'): d.get('tsym') for d in my_dict['1'] if 'token' in d and 'tsym' in d}
# 或者处理None值
dct = {d['token']: d.get('tsym', 'N/A') for d in my_dict['1'] if 'token' in d}本教程展示了如何利用Python的字典推导式,从复杂的嵌套字典数据中高效地提取和重构信息。通过理解数据结构和明确转换目标,我们可以编写出简洁、功能强大的代码,将原始数据转换为更符合业务逻辑需求的格式。掌握字典推导式是Python数据处理能力提升的重要一步,它能帮助开发者更有效地处理和分析各种复杂数据集。
以上就是Python中嵌套字典数据的高效过滤与转换的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号