我有一个python字典
d = {
"Random" : [1,2,3], "Stupid" : [1], "Gross" : [1,1,1,1,1], "Ugly" : [2,1,1,1]
}
以上列表应根据列表值的count
进行排序。
我试过了:sorted(d, key=d.get, reverse=True)
但我似乎没有得到正确的结果。
答案 0 :(得分:4)
您的意思是length
吗?
>>> sorted(d, key=lambda k: -len(d[k]))
['Gross', 'Ugly', 'Random', 'Stupid']
>>> sorted(d, key=lambda k: len(d[k]), reverse=True)
['Gross', 'Ugly', 'Random', 'Stupid']
答案 1 :(得分:1)
因为你是从一本字典开始的,所以你需要以一个而不是一个列表来结束:
>>> import collections
>>> d = {
... "Random" : [1,2,3], "Stupid" : [1], "Gross" : [1,1,1,1,1], "Ugly" : [2,1,1,1]
... }
>>> sd = collections.OrderedDict(sorted(d.items(), key=lambda t: -len(t[1])))
>>> sd
OrderedDict([('Gross', [1, 1, 1, 1, 1]), ('Ugly', [2, 1, 1, 1]), ('Random', [1, 2, 3]), ('Stupid', [1])])
>>>