从带有列表的列表中获取最大值?

Posted

技术标签:

【中文标题】从带有列表的列表中获取最大值?【英文标题】:Get max value from a list with lists? 【发布时间】:2016-01-21 01:16:51 【问题描述】:

所以我有一个包含几个列表的列表,这些列表首先包含三个字符串,然后是一个浮点数,例如:

resultlist = [["1", "1", "a", 8.3931], ["1", "2", "b", 6.3231], ["2", "1", "c", 9.1931]]

如何创建一个返回最大值(此处为 9.1931)的函数?我试过了

def MaxValue():
    max_value = max(resultlist)
    return max_value

但这只是给了我一个清单。

编辑:另外,我可以通过什么方式获取值来自何处的索引?比如,来自哪个子列表?

【问题讨论】:

【参考方案1】:

遍历您的外部列表并选择每个子列表的最后一个元素:

def max_value(inputlist):
    return max([sublist[-1] for sublist in inputlist])

print max_value(resultlist)
# 9.1931

最好将所有与函数相关的变量都保留在范围内(将列表作为参数传递,不要通过重用变量名来混淆命名空间)。

【讨论】:

你会得到最后一个元素,因为你知道列表是有序的,并且每个列表中最后一个元素总是较大的?? @EmiliOrtega 这个答案对这个问题非常具体---“我有一个包含几个列表的列表,这些列表首先都有三个字符串,然后是一个浮点数”---所以这个解决方案得到了最后一个元素,因为那是数字所在的位置。 是的,我的意思是,如果你有一个 [["1", "1", "a", 10, 8.3931], ....] 这样的列表,它会仍然返回 8.3 而不是 10 对吗? 正确。 sublist[-1] 返回每​​个子列表中的最后一个值。它与排序无关。【参考方案2】:

也许比pythonic方式更实用:

>>> max(map(lambda x: x[3], resultlist))
9.1931

它首先将结果列表的每个元素映射到数字值,然后找到最大值。

中间数组是:

>>> map(lambda x: x[3], resultlist)
[8.3931000000000004, 6.3231000000000002, 9.1930999999999994]

【讨论】:

【参考方案3】:

Numpy 有助于数字嵌套列表。试试这个:

resultlist = [[3, 2, 4, 4], [1, 6, 7, -6], [5, 4, 3, 2]]
max(resultlist)  # yields [5, 4, 3, 2] because 5 is the max in: 3, 1, 5
np.max(resultlist)  # yields 7 because it's the absolute max

max() 返回第一个元素是所有列表第一个元素的最大值的列表,而np.max() 返回所有嵌套列表中的最大值。

【讨论】:

这绝对应该是公认的答案——它提供了一个通用的解决方案,而不是公认的答案提供的超级特定于当前列表设置的解决方案。【参考方案4】:

如果你也想要索引,你可以使用enumerateoperator.itemgetter 使用map

from operator import itemgetter
def max_val(l, i):
    return max(enumerate(map(itemgetter(i), l)),key=itemgetter(1)))

这将返回一个带有索引的最大值的元组:

In [7]: resultlist = [["1", "1", "a", 8.3931], ["1", "2", "b", 6.3231], ["2", "1", "c", 9.1931]]

In [8]: max_val(resultlist, -1)
Out[8]: (2, 9.1931)

或者只是一个普通的 gen exp:

from operator import itemgetter
def max_val(l, i):
    return max(enumerate(sub[i] for sub in l), key=itemgetter(1))

【讨论】:

+1 表示“itemgetter”。但是,我认为函数“max_val”的第一个定义有问题,至少我收到了 SyntaxError - 我猜括号有问题。 你能删除它吗?我没有足够的声望来编辑它!? ;) 好的,它会在某个时候出现。但是很好的解决方案!我现在也在下面的解决方案中加入了 itemgetter。【参考方案5】:
resultlist = [["1", "1", "a", 8.3931], ["1", "2", "b", 6.3231], ["2", "1", "c", 9.1931]]
print(max(map(lambda x: x[-1],resultlist)))

输出:

9.1931

【讨论】:

【参考方案6】:

您是否想从浮点数(列表中的最后一个索引)中获取最大数量?如果是这样,这里有一个解决方案。

last_indices = [x[3] for x in resultlist]
return max(last_indices)

【讨论】:

为什么使用sorted()[0] 而不是max()?对列表进行排序以获得最大的价值是一个巨大的性能损失。 @wflynny 我编辑了我的答案,因为你实际上发表了你的评论,哈哈。【参考方案7】:

这是一个答案,以防万一你得到一个数字并不总是在第三位的列表:

from itertools import chain
max(filter(lambda x: isinstance(x, (int, long, float)), chain.from_iterable(resultlist)))

发生了什么事? itertools.chain 展平列表列表,filter 然后选择所有数值,然后使用 max 函数确定最大值。 这里的优点是它也适用于任意列表列表,其中数值可以在列表中的任何位置找到。

你的例子:

resultlist = [['1', '1', 'a', 8.3931], ['1', '2', 'b', 6.3231], ['2', '1', 'c', 9.1931]]
max(filter(lambda x: isinstance(x, (int, long, float)), chain.from_iterable(resultlist))) 
#prints 9.1931

一个更一般的例子:

myList = [[23, 34, 'a'],['b'],['t', 100]]
max(filter(lambda x: isinstance(x, (int, long, float)), chain.from_iterable(myList)))
#prints 100

编辑:

如果您还想获取最大值的索引,您可以执行以下操作(使用@Padraic Cunningham 方法):

from itertools import chain
import operator
resultlist = [['1', '1', 'a', 8.3931], ['1', '2', 'b', 6.3231], ['2', '1', 'c', 9.1931]]
l = filter(lambda x: isinstance(x, (int, long, float)), chain.from_iterable(resultlist))
# l: [8.3931, 6.3231, 9.1931]
max(enumerate(l), key = operator.itemgetter(1))
#(2, 9.1931)

这种方法假设每个列表只有一个数值!

另一个使用列表的示例,其中数值位于任意位置:

from itertools import chain
import operator
myList = [[23, '34', 'a'],['b', 1000],['t', 'xyz', 100]]
l=filter(lambda x: isinstance(x, (int, long, float)), chain.from_iterable(myList))
max(enumerate(l), key = operator.itemgetter(1))
#prints (1, 1000)

【讨论】:

【参考方案8】:

正如其他人所提到的,您可以用更笼统的术语回答这个问题(即使没有额外的库)。

maxval = max(map(max, resultlist))
print(maxval)

这会获取具有最大值的内部列表,然后将 max 函数映射到该内部列表上以找到最大值并将其存储在 maxval 中。

【讨论】:

如何摆脱警告“预期类型 Iterable,得到 _dict_values 而不是”?【参考方案9】:

另一种获得答案的方法是使用列表推导:

>>> max([x[3] for x in resultlist])
9.1931

【讨论】:

以上是关于从带有列表的列表中获取最大值?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用java流从列表中获取前5个最大值

使用带有最小值和最大值的 jQuery 验证体验下拉列表

从 int 列表中获取最大最接近的数字

python 从对象列表中获取最大属性值

从日期字符串列表中获取最大日期

scala:从变量列列表中获取与最大列值对应的列名