news 2026/3/11 1:21:50

Python 一行代码实现计数统计:dict.get() 的巧妙用法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python 一行代码实现计数统计:dict.get() 的巧妙用法

Python 一行代码实现计数统计:dict.get()的巧妙用法

在 Python 中统计元素出现次数是一个常见需求。今天分享一个经典且优雅的写法,只需一行代码就能搞定:

app_stats[entry.app_id]=app_stats.get(entry.app_id,0)+1

场景还原

假设我们在分析日志,需要统计每个app_id出现的次数:

fromtypingimportDict# 假设 self.entries 包含多条日志记录app_stats:Dict[int,int]={}# 用于存储统计结果forentryinself.entries:# 统计每个 app_id 出现的次数app_stats[entry.app_id]=app_stats.get(entry.app_id,0)+1# 输出结果示例:{15: 3, 16: 2, 17: 1}# 表示 app_id=15 出现3次,16出现2次,17出现1次

拆解这行代码

app_stats[entry.app_id]=app_stats.get(entry.app_id,0)+1│ │ │ │ │ │ │ │ │ └─ 如果不存在,从0开始计数 │ │ │ └─ 查找的键(app_id) │ │ └─ dict.get(key,default)方法 │ └─ 将结果存回字典 └─ 目标字典

执行逻辑:

情况get()返回值计算结果效果
app_id第一次出现0(默认值)0 + 1 = 1初始化计数为1
app_id已存在当前计数(如3)3 + 1 = 4计数加1

为什么用get()而不是[]

Python 字典有两种访问方式:

# 方式1:用 [] 访问(不推荐用于计数)app_stats[15]# 如果15不存在,直接抛出 KeyError!# 方式2:用 get() 访问(推荐)app_stats.get(15,0)# 如果15不存在,返回默认值 0,不报错

dict.get(key, default)的优势:

  • 键存在时:返回对应的值
  • 键不存在时:返回指定的默认值(不会报错)
  • 完美适合"第一次初始化,之后累加"的场景

执行流程图解

假设日志中的app_id序列为:[15, 15, 15, 16, 16]

初始:app_stats={}1(15):get(15,0)→ 返回00+1=1→ app_stats={15:1}2(15):get(15,0)→ 返回11+1=2→ app_stats={15:2}3(15):get(15,0)→ 返回22+1=3→ app_stats={15:3}4(16):get(16,0)→ 返回00+1=1→ app_stats={15:3,16:1}5(16):get(16,0)→ 返回11+1=2→ app_stats={15:3,16:2}最终结果:{15:3,16:2}

对比:冗长写法 vs 简洁写法

传统写法(需要 if-else):

ifentry.app_idinapp_stats:app_stats[entry.app_id]=app_stats[entry.app_id]+1else:app_stats[entry.app_id]=1

优雅写法(一行搞定):

app_stats[entry.app_id]=app_stats.get(entry.app_id,0)+1

对比结果:

  • ✅ 代码更简洁(1行 vs 4行)
  • ✅ 逻辑更清晰(无需分支判断)
  • ✅ 效率更高(只查询一次字典)

实际应用场景

这种写法广泛应用于:

# 1. 词频统计word_count={}forwordintext.split():word_count[word]=word_count.get(word,0)+1# 2. 投票统计votes={}forvoteinballot:votes[vote]=votes.get(vote,0)+1# 3. 错误日志统计error_stats={}forerrorinlog_errors:error_stats[error.code]=error_stats.get(error.code,0)+1

进阶:用 collections.Counter

如果你不需要手动控制过程,Python 提供了更高级的工具:

fromcollectionsimportCounter# 一行代码完成全部统计app_stats=Counter(entry.app_idforentryinself.entries)# 结果:Counter({15: 3, 16: 2})

但在需要自定义统计逻辑边遍历边处理的场景下,dict.get()的写法依然是最灵活、最经典的选择。

总结

stats[key]=stats.get(key,0)+1

这行代码堪称 Python 计数字典的标准范式

  • 利用get()的默认值特性,巧妙地解决了"初始化+累加"的问题
  • 将原本需要条件判断的逻辑压缩成一行
  • 既安全又高效,是 Pythonic 代码的典型代表

下次需要统计元素频次时,试试这行代码吧!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/11 12:39:09

还得是腾讯,Claude Code迎来最强中国对手!企业Agent有救了~

大家好,我是最近天天折腾CLI Agent的袋鼠帝。 一周前,我给大家安利了一款Claude Code的最强开源对手:OpenCode,没想到文章发出去后反响这么热烈,不管是阅读量还是评论都非常多。 这也再次印证了,天下苦Ant…

作者头像 李华
网站建设 2026/3/11 15:11:56

深入解析微软Outlook远程代码执行高危漏洞(CVE-2023-36895)

Microsoft Outlook 远程代码执行漏洞 (CVE-2023-36895) 摘要 本文讨论了于2023年8月8日发布的关键安全漏洞CVE-2023-36895,该漏洞与微软Outlook相关。文章分析了该漏洞的影响、严重性及其潜在风险,并探讨了微软为解决此漏洞提供的修复步骤和官方补丁。 引…

作者头像 李华
网站建设 2026/3/10 22:40:27

爆火的AI Agent究竟是啥?一篇文章给你讲透!(内含实例)

*一、前言:AI Agent火爆登场!* 要说今年上半年科技圈的“网红”,AI Agent(人工智能代理)绝对算一个!笔者最近也紧跟潮流,对这玩意儿进行了深入研究,还用智能体开发平台搞了几个有意…

作者头像 李华
网站建设 2026/3/5 5:28:22

银行反洗钱工作,身份核验添技术支撑

反洗钱是银行合规运营的核心要求,而精准识别客户身份是反洗钱工作的基础。护照阅读器可与银行反洗钱系统、客户识别系统无缝对接,读取护照信息后自动检索风险数据库,快速识别高风险客户或可疑交易线索。通过OCR数据与电子芯片内容交叉验证&am…

作者头像 李华
网站建设 2026/3/9 16:56:59

资源泄露:为什么你的文件句柄总是“莫名其妙”耗尽?

🚀 引言:谁动了我的句柄? “java.io.IOException: Too many open files”。 看到这个报错时,你的服务器可能已经陷入了“半死不活”的状态:无法建立新的数据库连接、无法读取配置文件、甚至连 SSH 都可能连不上。最诡异…

作者头像 李华
网站建设 2026/3/11 3:22:53

学生近视低龄化引关注,教育照明护眼灯成防控关键

从近些年来开始,我国学生所面临的近视状况愈发日益显著地获取社会瞩目。依据《国民视觉健康》调研所形成的数据,在年龄超过5岁的人群范围里,近视所占比例已经达到了35%至39%左右这个区间,并且呈现出年龄朝着低龄化方向变化的态势。…

作者头像 李华