7

可能重复:
按嵌套列表中的第二个元素排序或查找最大值。Python

我编写了一个程序,它给了我一个元组列表。我需要用第二个值中的最大数来获取元组。

    (840, 32), (841, 3), (842, 4), (843, 4), (844, 6), (845, 6), (846, 12), (847, 6), (848, 10), (849, 4), ..snip...

我需要返回 (840,32) 因为 32 是元组中最高的第二个数字。我怎样才能做到这一点?我尝试了多种方法,但一直卡在这里是完整的代码:

    D = {}
    def divisor(n):
        global D
        L = []
        for i in range(1,n+1):
        if n % i == 0:
            L.append(i)
            D[n] = len(L)

    for j in range(1001):
        divisor(j)


    print(D.items())
4

1 回答 1

37

max()与 一起使用lambda

In [22]: lis=[(840, 32), (841, 3), (842, 4), (843, 4), (844, 6), (845, 6), (846, 12), (847, 6), (848, 10), (849, 4)]

In [23]: max(lis, key=lambda x:x[1])
Out[23]: (840, 32)

operator.itemgetter

In [24]: import operator 

In [25]: max(lis, key=operator.itemgetter(1))
Out[25]: (840, 32)
于 2012-10-23T21:05:32.243 回答