按值对字典的内容进行排序已经有详细的描述,因此可以通过以下方式实现:
d={'d':1,'b':2,'c':2,'a':3}
sorted_res_1= sorted(d.items(), key=lambda x: x[1])
# or
from operator import itemgetter
sorted_res_2 = sorted(d.items(), key=itemgetter(1))
我的问题是,实现以下输出的最佳方法是什么:
[('d', 1), ('b', 2), ('c', 2), ('a', 3)] 而不是 [('d', 1), ('c', 2 ), ('b', 2), ('a', 3)]
以便元组按值排序,然后按键排序,如果值相等。
其次 - 这是否有可能逆转:
[('a', 3), ('b', 2), ('c', 2), ('d', 1)] 而不是 [('a', 3), ('c', 2 ), ('b', 2), ('d', 1)]?
最佳答案
sorted
key
参数可以返回一个元组。在这种情况下,元组中的第一项用于对项目进行排序,第二项用于打破平局,第三项用于仍然平局的项目,依此类推......
In [1]: import operator
In [2]: d={'d':1,'b':2,'c':2,'a':3}
In [3]: sorted(d.items(),key=operator.itemgetter(1,0))
Out[3]: [('d', 1), ('b', 2), ('c', 2), ('a', 3)]
operator.itemgetter(1,0)
返回一个由第二项和第一项组成的元组。也就是说,如果 f=operator.itemgetter(1,0)
则 f(x)
返回 (x[1],x[0])
。关于python - 按值和键对字典的内容进行排序,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/7076108/