Python字典排序本质是生成有序键值对序列:按键排序用sorted(d.items()),按值排序需key=lambda x: x[1],结果可转字典或保留为列表,原字典不变。

Python 中字典本身是无序的(Python 3.7+ 虽然保持插入顺序,但这不是“排序”意义上的有序),所以「对字典排序」实际是指:基于键、值或其他规则,生成一个**有序的键值对序列**(如列表或新字典)。
按键排序
用 sorted() 对字典的 .keys() 或直接对字典(等价于遍历键)排序,再用字典推导式或 dict() 构造新字典:
d = {'banana': 3, 'apple': 4, 'cherry': 1}
# 升序(默认)
sorted_by_key = dict(sorted(d.items())) # {'apple': 4, 'banana': 3, 'cherry': 1}
# 降序
sorted_by_key_desc = dict(sorted(d.items(), reverse=True))
按值排序
关键是在 sorted() 中指定 key= 参数,用 lambda x: x[1] 提取每个键值对的值(索引 1):
d = {'banana': 3, 'apple': 4, 'cherry': 1}
sorted_by_value = dict(sorted(d.items(), key=lambda x: x[1]))
# {'cherry': 1, 'banana': 3, 'apple': 4}
按值降序
sorted_by_value_desc = dict(sorted(d.items(), key=lambda x: x[1], reverse=True))
排序后保留为列表(更常用)
如果只是需要遍历或处理,不一定要转回字典。返回 list of tuples 更灵活、更高效:
立即学习“Python免费学习笔记(深入)”;
-
sorted(d.items())→ 按键升序的列表,如[('apple', 4), ('banana', 3), ...] -
sorted(d.items(), key=lambda x: x[1])→ 按值升序的列表 - 可直接用于 for 循环:
for k, v in sorted(d.items(), key=lambda x: x[1]): print(k, v)
注意点
- 原字典 不会被修改,所有排序操作都返回新对象
- 如果值不可比较(比如混有字符串和数字、或有 None),排序会报 TypeError
- 想稳定排序多个条件?可以传元组给 key,例如
key=lambda x: (x[1], x[0])先按值、再按键排序
基本上就这些。核心就是 sorted(d.items(), key=...),其他都是围绕它展开的变形。











