Python字典遍历应直接用for key in d而非d.keys(),因字典本身可迭代且默认遍历键;d.items()返回动态视图,不可索引或排序,需转list才能切片或多次遍历;遍历时修改字典仅.d.keys()和.items()会报RuntimeError,安全做法是先收集待删键再批量删除。

直接用 for key in d 最省事,别一上来就调 .keys()
Python 字典本身就是可迭代对象,for key in d 默认遍历的是键(key),和写 for key in d.keys() 效果一样,但少一次方法调用、少建一个视图对象。很多人习惯性加 .keys(),纯属多此一举。
常见错误现象:for k in d.keys(): v = d[k] —— 这种写法在键是不可哈希类型(比如嵌套 list)时会出错,而且多了一次查表开销;更关键的是,如果循环中意外修改了字典(比如 del d[k]),.keys() 视图可能抛 RuntimeError: dictionary changed size during iteration。
- 只取键:直接
for key in d - 只取值:用
for value in d.values(),注意它不保证顺序(Python 3.7+ 保持插入序,但逻辑上不应依赖) - 要键值对:必须用
for key, value in d.items(),别拆成两次查d[k]
.items() 返回的是视图,不是列表,不能索引也不能排序
d.items() 返回的是 dict_items 对象,它是动态视图——字典变了,视图内容跟着变。这意味着你不能对它做 items[0] 或 sorted(items)(会报 TypeError: 'dict_items' object is not subscriptable 或无法直接排序)。
使用场景:想边遍历边过滤或转换?得先转成 list 或用生成器表达式。比如按值排序后取前 3 个键值对:sorted(d.items(), key=lambda x: x[1], reverse=True)[:3] —— 这里 sorted() 强制转成了 list,视图特性就没了。
立即学习“Python免费学习笔记(深入)”;
- 需要索引/切片/多次遍历 → 显式转
list(d.items()) - 只遍历一次且不改原字典 → 直接
for k, v in d.items(),省内存 - 想按值排序再遍历 → 必须
sorted(d.items(), key=...),不能sorted(d.items().values())(语法错)
遍历时修改字典,只有 .keys() 和 .items() 视图会报错
Python 不允许在遍历字典的同时增删键,但具体报错时机取决于你用什么方式遍历:for k in d 和 for k in list(d) 都不会当场报错(后者因为 list 是静态快照),而 for k in d.keys() 或 for k, v in d.items() 会在下一次迭代时检查字典结构,一旦发现变化就抛 RuntimeError。
性能影响:视图对象本身轻量,但每次迭代都做“结构校验”,有微小开销;而 list(d.keys()) 一次性复制全部键,内存占用随字典大小线性增长。
- 安全修改字典 → 先收集要删的键:
to_delete = [k for k, v in d.items() if v < 0]; [d.pop(k) for k in to_delete] - 想边遍历边更新值 → 可以,只要不增删键:
for k in d: d[k] *= 2是合法的 - 不确定是否修改 → 统一用
for k in list(d):最稳妥
Python 3.8+ 的 reversed() 不支持字典视图,但可以反向遍历键
reversed(d.items()) 会报 TypeError: argument to reversed() must be a sequence,因为 dict_items 不是序列类型。但字典本身从 3.7 开始保持插入顺序,所以你可以用 for k in reversed(list(d)): 来倒序遍历键(值和键值对同理)。
兼容性影响:这个技巧在 3.6(CPython)也能用,但属于实现细节;3.7+ 才是语言保证。如果你的代码要跑在旧版本或 PyPy 上,别依赖 reversed(list(d)) 的语义一致性。
- 倒序遍历键 →
for k in reversed(list(d)): - 倒序遍历键值对 →
for k, v in reversed(list(d.items())): - 注意
list(d.items())是两层嵌套 list,比list(d)更占内存










