python 如何进行元组排序

python list 可以直接进行sort排序,默认是按照从小到大进行排序.
现在有个需求:要按照元组的第一个元素进行升序,但是按照第二个元素进行降序
如下是个取巧的办法,这里的100根据数值范围进行调整,思路是选择一个函数,对第一个元素是增函数,第二个元素是减函数
# sorted(L)
L = [(0, 2), (0, 12), (1 , 66), (1, 88)]
L.sort(key=lambda x: 100*x[0]-x[1])
print(L)

正规的写法如下

L = [(0, 2), (0, 12), (1 , 66), (1, 88)]
 

from operator import itemgetter, attrgetter

def multisort(xs, specs):
    for key, reverse in reversed(specs):
        xs.sort(key=itemgetter(key), reverse=reverse)
    return xs


multisort(L, ((0, False), (1, False)))
参考:https://docs.python.org/3/howto/sorting.html

你可能感兴趣的:(python)