
本文介绍了如何根据特定条件高效地过滤Python字典,并创建两个新的字典,分别包含符合条件的键值对。通过使用dict.items()迭代字典项和any()函数进行条件判断,避免了不必要的列表转换和嵌套循环,从而提高了代码的效率和可读性。文章提供了详细的代码示例和解释,帮助读者理解和应用这种高效的字典过滤方法。
在Python编程中,经常需要根据某些条件从现有字典中提取数据,并创建新的字典。例如,根据字典的值是否包含特定的字符串来分类数据。本文将介绍一种高效的方法,使用dict.items()迭代字典项,并结合any()函数进行条件判断,从而避免不必要的列表转换和嵌套循环,提高代码的效率和可读性。
字典过滤的常见需求
假设我们有一个字典,其中键是字符串类型的ID,值是包含特定代码的字符串。我们需要根据这些代码将字典分成两个新的字典:一个包含以 “23C1″、”23C2″、”24C2” 或 “24C1” 开头的代码的键值对,另一个包含以 “23P1″、”23P2″、”24P2” 或 “24P1” 开头的代码的键值对。
高效的字典过滤方法
以下代码展示了如何使用 dict.items() 和 any() 函数来实现高效的字典过滤:
立即学习“Python免费学习笔记(深入)”;
快转字幕
新一代 AI 字幕工作站,为创作者提供字幕制作、学习资源、会议记录、字幕制作等场景,一键为您的视频生成精准的字幕。
357 查看详情
dct = {'48689': 'FINNIFTY02JAN24C20900', '46624': 'FINNIFTY09JAN24P20900', '40811': 'NIFTY14DEC23C20750', '40812': 'NIFTY14DEC23P20750', '40813': 'NIFTY14DEC23C20800', '40814': 'NIFTY14DEC23P20800', '40817': 'NIFTY14DEC23C20850', '40818': 'NIFTY14DEC23P20850', '40828': 'NIFTY14DEC23C20900', '40832': 'NIFTY14DEC23P20900', '40834': 'NIFTY14DEC23C20950', '40839': 'NIFTY14DEC23P20950'}dict_C = {}dict_P = {}arrC = ["23C1", "23C2", "24C2", "24C1"]arrP = ["23P1", "23P2", "24P2", "24P1"]for key, value in dct.items(): if any(x in value for x in arrC): dict_C[key] = value elif any(x in value for x in arrP): dict_P[key] = valueprint("dict_C -", dict_C)print("dict_P -", dict_P)
代码解释:
初始化空字典: 首先,我们创建两个空字典 dict_C 和 dict_P,用于存储过滤后的键值对。定义过滤条件列表: arrC 和 arrP 分别存储用于过滤 C 类和 P 类代码的字符串列表。迭代字典项: 使用 dct.items() 方法迭代原始字典 dct 的键值对。使用 any() 函数进行条件判断: any(x in value for x in arrC) 检查 value 中是否包含 arrC 列表中的任何一个字符串。如果包含,则将当前的键值对添加到 dict_C 中。elif any(x in value for x in arrP) 同理,检查 value 中是否包含 arrP 列表中的任何一个字符串,如果包含,则将当前的键值对添加到 dict_P 中。
输出结果:
dict_C - {'48689': 'FINNIFTY02JAN24C20900', '40811': 'NIFTY14DEC23C20750', '40813': 'NIFTY14DEC23C20800', '40817': 'NIFTY14DEC23C20850', '40828': 'NIFTY14DEC23C20900', '40834': 'NIFTY14DEC23C20950'}dict_P - {'46624': 'FINNIFTY09JAN24P20900', '40812': 'NIFTY14DEC23P20750', '40814': 'NIFTY14DEC23P20800', '40818': 'NIFTY14DEC23P20850', '40832': 'NIFTY14DEC23P20900', '40839': 'NIFTY14DEC23P20950'}
优势与注意事项
效率: dict.items() 提供了高效的字典迭代方式,避免了创建中间列表。any() 函数在找到第一个匹配项后立即停止,避免了不必要的循环。可读性: 代码结构清晰,易于理解和维护。灵活性: 可以轻松地修改过滤条件,以适应不同的需求。
注意事项:
确保过滤条件列表 arrC 和 arrP 包含所有需要匹配的字符串。如果字典的值需要进行更复杂的模式匹配,可以考虑使用正则表达式。
总结
本文介绍了一种使用 Python 高效过滤字典并创建新字典的方法。通过使用 dict.items() 迭代字典项和 any() 函数进行条件判断,避免了不必要的列表转换和嵌套循环,从而提高了代码的效率和可读性。这种方法可以广泛应用于各种需要根据特定条件从字典中提取数据的场景。
以上就是使用Python高效过滤字典并创建新字典的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/614777.html
微信扫一扫
支付宝扫一扫