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}
<h1>按值降序</h1><p>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 k, v in sorted(d.items(), key=lambda x: x[1]): print(k, v)
key=lambda x: (x[1], x[0]) 先按值、再按键排序基本上就这些。核心就是 sorted(d.items(), key=...),其他都是围绕它展开的变形。
以上就是python中怎样将字典排序的详细内容,更多请关注php中文网其它相关文章!
python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号