.items()在需键值对时最快,因C层一次性取键值避免重复哈希;.keys()/.values()在单用场景略快但差异极小;真正瓶颈是循环体内操作而非遍历方法本身。

直接说结论:.items() 在需要键值对时最快,.keys() 和 .values() 各自场景下比 .items() 略快,但差异极小;真正拖慢遍历的从来不是方法名,而是循环体内的操作——尤其是重复查字典、隐式类型转换或字符串拼接。
为什么 .items() 通常比 for k in d: d[k] 快?
显式用 for k in d: d[k] 会触发两次哈希查找:一次定位键,一次取值;而 .items() 迭代器在 C 层一次性取出键和值,避免重复计算哈希和探针。CPython 3.7+ 的字典是插入有序的,.items() 还能利用内存局部性优势。
实操建议:
- 要同时用键和值,无条件选
.items(),别手写d[k] - 如果只读值,用
.values()——它不构造键对象,省内存(尤其键是长字符串或大对象时) - 避免
list(d.items())再遍历:这会强制复制全部键值对,O(n) 空间开销,纯属浪费
.keys() 和 in 查找的性能陷阱
key in d.keys() 和 key in d 表面相似,实际前者多一层包装对象调用,后者直接走字典的 __contains__,快 15–20%(实测 10 万次查找)。
立即学习“Python免费学习笔记(深入)”;
常见错误现象:
- 误以为
d.keys()返回的是 set,想当然地做d.keys() & other_set——其实返回的是dict_keys视图,支持交集但底层仍是哈希查找,不如转成set(d.keys())再算(仅当需多次复用时才值得) - 在循环里反复写
if k in d.keys(): ...——等价于if k in d:,但更慢还更啰嗦
Python 3.12+ 的新变化:.keys() / .values() 视图支持更多集合操作
3.12 开始,dict_keys 和 dict_values 支持 |(并集)、&(交集)、-(差集),但注意:.values() 的集合操作**不保证语义正确**,因为值可能重复,而集合去重会丢数据。
使用场景:
- 快速判断两个字典是否有相同键:
d1.keys() & d2.keys()✅ 安全且高效 - 想找出只在
d1有、d2没有的键:d1.keys() - d2.keys()✅ 推荐 - 千万别用
d1.values() & d2.values()判断“值是否重叠”——重复值会被合并,结果不可靠
真实瓶颈往往不在遍历方法本身
下面这段代码,无论你换 .items()、.keys() 还是 .values(),性能几乎没差别:
for k, v in data.items():
result.append(f"key={k}, value={v}") # 字符串格式化占 90% 时间
真正卡顿的是 f-string 构造和 list.append() 的内存分配。优化方向应是:
- 批量处理:用列表推导式替代循环 + append
- 避免重复序列化:如果
v是复杂对象,考虑提前缓存str(v) - 用生成器表达式 +
'\n'.join()替代逐条拼接
字典遍历方法之间的微秒级差异,在 I/O 或序列化面前根本不构成瓶颈——先 profile,再改代码,别猜。











