基于最后一个元素的Python元组排序

参见英文答案 > Tuple pairs, finding minimum using python                                    3个
这是我的问题我有tuple1 = [(1,3),(3,2),(2,1)]我想根据每个元组的最后一个数字排序元组,所以结果将看起来像这样
输出= [(2,1),(3,2),(1,3)]
下面是我的代码

    i=0
for x in tuples:
    c.append(x[len(x)-1])
    last=sorted(c)
    for y in last.iteritems():
        if(y in x[len(x)-1]):
            print x             
            #b.insert(i,x)
i=i+1

运行iam后收到错误消息

    Traceback (most recent call last):
    File "x.py", line 47, in <module>
   sort_last([(1, 3), (3, 2), (2, 1)])
  File "x.py", line 35, in sort_last
 if(y in x[len(x)-1]):
  TypeError: argument of type 'int' is not iterable

解决方法:

在sorted函数中指定key参数.

>>> tuple1=[(1, 3), (3, 2), (2, 1)]
>>> output = sorted(tuple1, key=lambda x: x[-1])
>>> print output
[(2, 1), (3, 2), (1, 3)]

sorted函数(以及list.sort方法)有一个可选的key参数,用于指定对列表进行排序的内容.

上一篇:python – 将列表的每个元素转换为元组


下一篇:python – 对深度嵌套的元组进行排序