Python-返回N个列表中最大的一个
我想有一个函数返回最大的N列表。列表中有两项我可以写:Python-返回N个列表中最大的一个,python,list,Python,List,我想有一个函数返回最大的N列表。列表中有两项我可以写: l1 = [3, 4, 5] l2 = [4, 5, 6, 7] def f(L): if(len(L[0]) > len(L[1])): return L[0] else: return L[1] 我使用f([l1,l2])运行它 然而,随着列表的增多,它会变成一连串的if语句,这很难看 如何高效地返回N个列表中最大的列表?与key=len一起使用 In [3]: max([l1,
l1 = [3, 4, 5]
l2 = [4, 5, 6, 7]
def f(L):
if(len(L[0]) > len(L[1])):
return L[0]
else:
return L[1]
我使用f([l1,l2])
运行它
然而,随着列表的增多,它会变成一连串的if语句,这很难看
如何高效地返回N个列表中最大的列表?与key=len
一起使用
In [3]: max([l1, l2], key=len)
Out[3]: [4, 5, 6, 7]
这将为列表列表检索(第一个)最长的列表
事实上,这也适用于字符串(以及具有len属性的其他对象)
注意:我们还可以将项作为参数传入:
In [7]: max(l1, l2, key=len)
Out[7]: [4, 5, 6, 7]
max
读取:当(如果您通过key
)从key
的角度查看时,获取列表中最大的项目它大致相当于以下代码*(在Python3中),但实际的源代码是(效率更高,并且经过实际测试,因此请继续使用max,而不是这个!)
*我把它作为一个练习,使用迭代器而不是列表来编写它。。。并修复任何其他错误 哇,我不知道那个功能。令人惊叹的!这真是一个很好的方法
In [7]: max(l1, l2, key=len)
Out[7]: [4, 5, 6, 7]
def my_max(*L, key=None): # in python 2 we'd need to grab from kwargs (and raise type error if rogue keywords are passed)
L = list(L[0]) if len(L) == 1 else L # max takes iterable as first argument, or two or more arguments...
if not L:
raise ValueError("my_max() arg is an empty sequence")
if key is None: # if you don't pass a key use the identity
key = lambda x: x
max_item, max_size = L[0], key(L[0])
for item in L[1:]:
if key(item) > max_size:
max_item, max_size = item, key(item)
return max_item