python中怎样将字典排序
发布时间:2025-12-04 21:08
发布者:网络
浏览次数: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):
星辰Agent
科大讯飞推出的智能体Agent开发平台,助力开发者快速搭建生产级智能体
378
查看详情
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 更灵活、更高效:
-
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=...),其他都是围绕它展开的变形。
以上就是python中怎样将字典排序的详细内容,更多请关注其它相关文章!
# python
# 字典排序
# app
# apple
# 键值对
# 键值
# 升序
# 递归
# 遍历
# 会报
# 如何使用
# 做多
# 应用技巧
# 都是
# 全局变量
# 日照网站建设市场分析
# 小雨SEO优化
# 承德网站搜索优化
# 河南排名关键词
# 咸宁大气网站建设哪家好
# 南川区手机网站建设推广
# 淮安品牌网站建设市价
# 沙井网站优化价格
# 晋中网络营销推广方法
# 百度pc关键词排名软件





(x[1], x[0])