我现在已经阅读了一些关于如何在python中对dict进行排序的帖子,问题是我找到的解决方案并没有按照正确的顺序对dict进行排序。我发现的是这个
results = sorted(results.items(), key=lambda x: x[1])
这会生成一个从最小到最大排序的键值对列表,我想从最大到最小。这里有什么简单的解决方法吗?
答案 0 :(得分:4)
反转清单:
results = sorted(results.items(), key=lambda x: x[1])
results.reverse()
甚至更好:
results = sorted(results.items(), key=lambda x: x[1], reverse=True)
或最佳:
results = sorted(results.items(), cmp=lambda a,b: b[1]-a[1])
虽然奇怪的是第一个选项是最快的:
In [48]: %timeit sorted(x.items(), key=lambda x: x[1]).reverse()
100000 loops, best of 3: 2.93 us per loop
In [49]: %timeit sorted(x.items(), key=lambda x: x[1], reverse=True)
100000 loops, best of 3: 3.24 us per loop
In [50]: %timeit sorted(x.items(), cmp=lambda a,b: b[1]-a[1])
100000 loops, best of 3: 3.11 us per loop