gpt4 book ai didi

python - 按第二个值对元组列表进行排序,reverse=True,然后按 key,reverse=False

转载 作者:IT老高 更新时间:2023-10-28 22:14:55 27 4
gpt4 key购买 nike

我需要首先对字典进行排序,值 reverse=True,对于重复值,按键排序 reverse=False

到目前为止,我有这个

dict = [('B', 3), ('A', 2), ('A', 1), ('I', 1), ('J', 1)]
sorted(dict.items(), key=lambda x: (x[1],x[1]), reverse=True)

返回...

[('B', 3), ('A', 2), ('J', 1), ('I', 1), ('A', 1)]

但我需要它:

[('B', 3), ('A', 2), ('A', 1), ('I', 1), ('J', 1)]

如您所见,当值相等时,我只能按照指定的递减方式对键进行排序...但是如何让它们以递增方式排序?

最佳答案

以下内容适用于您的输入:

d = [('B', 3), ('A', 2), ('A', 1), ('I', 1), ('J', 1)]
sorted(d,key=lambda x:(-x[1],x[0]))

由于您的“值”是数字,您可以通过更改符号轻松地反转排序顺序。

换句话说,这种排序按值(-x[1])(负号将大数字放在首位)排序,然后对于相同的数字,它根据排序键(x[0])。

如果您的值(value)观不能轻易被“否定”以将大项目放在首位,那么一个简单的解决方法是排序两次:

from operator import itemgetter
d.sort(key=itemgetter(0))
d.sort(key=itemgetter(1),reverse=True)

因为python的排序是稳定的。

关于python - 按第二个值对元组列表进行排序,reverse=True,然后按 key,reverse=False,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14466068/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com