使用Python高效过滤字典并创建新字典

使用python高效过滤字典并创建新字典

本文介绍了如何根据特定条件高效地过滤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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月11日 03:23:55
下一篇 2025年11月11日 03:24:48

相关推荐

  • 詹姆斯·永利(James Wynn)的兴衰,詹姆斯·永利(James Wynn)是一名超流利鲸鱼,将300万美元变成了1亿美元,一周之内损失了

    “我自3月份起开始涉足期货交易。在这之前,期货交易或者任何衍生品交易对我来说都是全新的领域,我仅专注于模因交易。” 以下是使用Python编写的一个简单感知机模型的代码。此模型适用于二进制分类任务。 import numpy as npclass Perceptron:””” 一个简单的二进制分类模…

    2025年12月8日
    000
  • AIOZ网络启动了AIOZ AI,这是第一个分散的AI模型和数据集市场

    大安塞(mahe island) – 塞舌尔(aioz)网路宣布推出aioz ai,这是首个完全基于depin的去中心化ai模型与数据集市场。 塞舌尔大安塞(Grand Anse) – 2025年3月27日 – 领先的区块链公司Aioz Network正在推动De…

    2025年12月8日
    000
  • 加密货币量化交易初学者指南:常见策略、优劣势风险介绍

    目录 什么是加密量化交易?历史与演变从自由裁量到数据驱动交易的转变核心概念加密量化交易的关键组成部分数据收集和处理算法开发回测策略执行系统加密量化交易中的常见策略均值回归动量交易统计套利机器学习模型优势与风险优势风险和局限性案例分析:假设CET代币交易场景场景设置策略开发回测结果经验教训加密量化交易…

    2025年12月7日
    000
  • 什么是Allora Network?如何运作?背后的愿景介绍

    目录 什么是Allora Network?Allora Network背后的愿景Allora Network如何运作:去中心化AI生态系统上下文感知推理合成:自我改进的引擎模块化主题:专业化和可扩展性激励结构和代币经济学开源和开发者工具隐私、安全和治理现实世界应用和影响挑战和未来之路结论常见问题AL…

    2025年12月7日
    000
  • Linux命令行中wc命令的实用技巧

    wc命令可统计文件的行数、单词数、字符数和字节数,常用-l统计行数,如wc -l /etc/passwd查看用户数量;结合grep可分析日志,如grep “error” logfile.txt | wc -l统计错误行数;-w统计单词数,-m统计字符数(含空格换行),-c统计…

    2025年12月6日 运维
    000
  • Linux命令行中locate命令的快速查找方法

    locate命令通过查询数据库快速查找文件,使用-i可忽略大小写,-n限制结果数量,-c统计匹配项,-r支持正则表达式精确匹配,刚创建的文件需运行sudo updatedb更新数据库才能查到。 在Linux命令行中,locate 命令是快速查找文件和目录路径的高效工具。它不直接扫描整个文件系统,而是…

    2025年12月6日 运维
    000
  • VSCode入门:基础配置与插件推荐

    刚用VSCode,别急着装一堆东西。先把基础设好,再按需求加插件,效率高还不卡。核心就三步:界面顺手、主题舒服、功能够用。 设置中文和常用界面 打开软件,左边活动栏有五个图标,点最下面那个“扩展”。搜索“Chinese”,装上官方出的“Chinese (Simplified) Language Pa…

    2025年12月6日 开发工具
    000
  • VSCode性能分析与瓶颈诊断技术

    首先通过资源监控定位异常进程,再利用开发者工具分析性能瓶颈,结合禁用扩展、优化语言服务器配置及项目设置,可有效解决VSCode卡顿问题。 VSCode作为主流的代码编辑器,虽然轻量高效,但在处理大型项目或配置复杂扩展时可能出现卡顿、响应延迟等问题。要解决这些性能问题,需要系统性地进行性能分析与瓶颈诊…

    2025年12月6日 开发工具
    000
  • VSCode的悬浮提示信息可以自定义吗?

    可以通过JSDoc、docstring和扩展插件自定义VSCode悬浮提示内容,如1. 添加JSDoc或Python docstring增强信息;2. 调整hover延迟与粘性等显示行为;3. 使用支持自定义提示的扩展或开发hover provider实现深度定制,但无法直接修改HTML结构或手动编…

    2025年12月6日 开发工具
    000
  • 解析复杂正则表达式中边界与回溯问题:以数字匹配为例

    本文探讨了一个复杂正则表达式在数字匹配中遇到的问题,特别是由于单词边界`\b`和不当的量词使用导致某些预期数字未能匹配。教程详细解释了如何通过替换`\b`结构、并引入原子组(possessive quantifiers)来防止不必要的回溯,从而优化正则表达式,确保精确匹配目标数字模式,提升正则匹配的…

    2025年12月6日 后端开发
    000
  • MySQL模糊查询:高效处理含空格和多格式电话号码

    在mysql数据库中,当电话号码字段包含多种格式和空格时,传统的`like`查询可能无法返回预期结果。本文将介绍如何利用`replace`函数在查询时动态移除电话号码中的空格,从而实现准确的模糊匹配。同时,我们还将探讨性能考量及数据标准化等最佳实践,帮助您优化数据库查询和数据质量。 挑战:含空格电话…

    2025年12月6日 后端开发
    000
  • 如何在Laravel中计算JSON字符串字段中各值的总和

    本教程将指导您如何在laravel应用中,从数据库中存储的json字符串字段(例如element_degree)中提取并计算每个记录(如用户)内所有键值对中数值的总和。通过遍历模型集合、解码json数据并累加其内部数值,您可以轻松地为每条记录生成一个聚合总和。 在现代Web开发中,我们经常需要在数据…

    2025年12月6日 后端开发
    000
  • Linux文件系统readlink命令使用方法

    readlink命令用于解析符号链接指向的实际路径,基本用法为readlink 文件名,-f选项可递归解析为绝对路径,常用于脚本中获取真实文件位置,如readlink -f “$0″确定脚本自身路径,结合which命令可追踪命令真实执行文件,-n、-q、-s等选项支持静默处理…

    2025年12月6日 运维
    000
  • VSCode后端:Flask应用调试指南

    答案:配置VSCode调试Flask需安装Flask、编写入口文件、在launch.json中设置调试参数,然后设断点并启动调试会话。具体步骤包括创建launch.json文件并配置program、env和args等选项,确保使用正确Python解释器,避免端口占用,最后通过运行和调试面板启动应用,…

    2025年12月6日 开发工具
    000
  • 如何管理和同步VSCode的扩展配置,以便在新设备上快速恢复开发环境?

    使用 Settings Sync 是最快方式,通过 GitHub 账号同步扩展、设置、快捷键和代码片段;也可手动导出扩展列表(code –list-extensions > extensions.txt)并在新设备安装,结合备份 settings.json 等配置文件实现环境快速恢…

    2025年12月6日 开发工具
    000
  • 无XHR请求时提取JavaScript动态生成内容的教程

    本教程探讨了在爬取网页时,当目标内容由javascript动态生成且无明显xhr请求时的数据提取策略。我们将揭示数据可能已内嵌于初始html或js代码中,并演示如何通过检查页面源代码、识别关键标识符来定位并提取这些隐藏的json格式数据,从而实现高效的网页内容抓取。 挑战:JavaScript动态内…

    2025年12月6日 web前端
    000
  • VSCode扩展包管理依赖解析

    VSCode扩展依赖通过package.json中的extensionDependencies声明,安装时自动解析并提示用户安装所需扩展,确保按顺序激活且禁止循环依赖,依赖间通过contributes.api共享功能,使用vsce打包时需手动处理生产依赖和性能优化,最终实现扩展间的协同运行与API调…

    2025年12月6日 开发工具
    000
  • Cloudinary 上传后临时文件未删除的解决方案与 React 错误排查

    本文旨在解决在使用 Cloudinary 进行文件上传后,临时文件未自动删除的问题,并提供针对 React UI 崩溃 “Objects are not valid as a React child” 错误的排查与修复方案。文章将深入探讨如何在文件上传完成后安全地删除临时文件…

    2025年12月6日 web前端
    000
  • VSCode代码转换:编码格式处理

    遇到乱码时先查看文件编码,点击右下角编码名称选择“通过编码重新打开”,尝试 UTF-8、GBK 等常用编码以正确显示内容;2. 确认后可选择“通过编码保存”将文件转换为 UTF-8 等标准编码,便于跨平台协作;3. 为避免重复操作,可在设置中将 “files.encoding&#8221…

    2025年12月6日 开发工具
    000
  • 从动态网页中提取JavaScript生成的内容

    本文旨在提供一种从动态网页中提取由JavaScript生成的内容的方法。通过分析网页的初始加载代码,寻找嵌入其中的JSON数据,我们可以有效地抓取目标信息,即使网页不使用额外的XHR请求。本文将详细介绍如何定位和提取这些数据,并提供相应的示例。 很多现代网站使用JavaScript动态生成内容,这给…

    2025年12月6日 web前端
    000

发表回复

登录后才能评论
关注微信