在python中对具有3个元素的元组列表进行排序

我有一些元组的列表.每个元组都有三个元素.我需要对列表进行排序.为了打破两个元组之间的关系,先看一下元组的第一个元素,然后如果仍然绑定,则查看第二个元素.列表如下.

L = [(1, 14, 0), (14, 1, 1), (1, 14, 2), (14, 2, 3), (2, 4, 4), (4, 11, 5), (11, -1000, 6)]

在C语言中,sort函数具有一个compare函数,并且可以简单地完成所有操作.但是我有时在python中尝试后无法弄清楚.有谁能够帮助我?

解决方法:

只需对列表进行排序;默认排序功能可以满足您的需求.

比较两个元组时,将根据它们的内容对其进行排序;首先对第一个元素进行排序,如果相等,则对第二个元素进行排序,依此类推.

演示:

>>> L = [(14, 2, 3), (1, 14, 0), (14, 1, 1), (1, 14, 2), (2, 4, 4), (4, 11, 5), (11, -1000, 6)]
>>> sorted(L)
[(1, 14, 0), (1, 14, 2), (2, 4, 4), (4, 11, 5), (11, -1000, 6), (14, 1, 1), (14, 2, 3)]

我将(14,2,3)元素向前移动以显示它仍在(14,1,1)之后进行排序.

Python的list.sort()方法和sorted()函数采用一个键函数,如果您需要不同的排序顺序,则该键函数将返回一个要在其上进行排序的值.例如,如果您想首先对最后一个元素进行排序,然后对第二个元素进行排序,依此类推,则可以使用:

sorted(L, key=lambda t: t[::-1])

lambda返回一个反向元组进行排序.传递给键的可调用对象将针对输入序列中的每个元素进行调用,以在排序之前“扩充”列表,就像您已经完成的那样:

[s[1] for s in sorted((key(s), s) for s in L)]

t [::-1]使用reversing slice.

有关更多详细信息,请参见Python Sorting HOWTO.

上一篇:java-Oracle无效标识符不理解字符串


下一篇:从python集合中获取唯一的元组