使用sorted和OrderedDict 对字典排序
https://blog.youkuaiyun.com/qq_34732088/article/details/79917192
test = {1: "a", 3: "d", 6: "g", 2: "c", 5: "e", 0: "f", 4: 'b'}
# 对字典的key值列表排序,返回列表
print(sorted(test.keys()))
# 对字典的键值对元组列表排序,按元组的第1个元素排序,也就是 key
# 返回的是一个元组列表
print(sorted(test.items(), key=lambda obj: obj[0]))
# 对字典的键值对元组列表排序,按元组的第2个元素排序,也就是 value
# 返回的是一个元组列表
print(sorted(test.items(), key=lambda obj: obj[1]))
[0, 1, 2, 3, 4, 5, 6]
[(0, 'f'), (1, 'a'), (2, 'c'), (3, 'd'), (4, 'b'), (5, 'e'), (6, 'g')]
[(1, 'a'), (4, 'b'), (2, 'c'), (3, 'd'), (5, 'e'), (0, 'f'), (6, 'g')]
from collections import OrderedDict
test = {1: "a", 3: "d", 6: "g", 2: "c", 5: "e", 0: "f", 4: 'b'}
print(OrderedDict(sorted(test.items(), key=lambda obj: obj[0])))
print(OrderedDict(sorted(test.items(), key=lambda obj: obj[1])))
OrderedDict([(0, 'f'), (1, 'a'), (2, 'c'), (3, 'd'), (4, 'b'), (5, 'e'), (6, 'g')])
OrderedDict([(1, 'a'), (4, 'b'), (2, 'c'), (3, 'd'), (5, 'e'), (0, 'f'), (6, 'g')])
dict() vs collections.OrderedDict()
https://blog.youkuaiyun.com/weixin_38145317/article/details/104971207
如果是普通的字典,即使传入的顺序不一样,但是依然是相同的字典;如果是orderedDict,传入的顺序不一样,那么得到的字典是不一样的。
本文介绍了如何使用Python内置函数sorted以及collections模块中的OrderedDict来对字典进行排序的方法。首先通过sorted函数对字典的键(key)进行排序,并展示了如何根据键值对中的值(value)来进行排序。接着,利用OrderedDict进一步实现排序后的有序字典,突出了其保持插入顺序的特点。
2461

被折叠的 条评论
为什么被折叠?



