使用max
函数及其key
参数,仅使用第二个元素比较列表中的元素。
例如,
>>> data = [[12587961, 0.7777777777777778], [12587970, 0.5172413793103449], [12587979, 0.3968253968253968].... [12588042, 0.9473684210
526315]]
>>> max(data, key=lambda item: item[1])
[12588042, 0.9473684210526315]
现在,如果只需要第一个元素,则可以仅获取第一个元素,或者仅将结果拆包,如下所示
>>> index, value = max(data, key=lambda item: item[1])
>>> index
12588042
>>> value
0.9473684210526315
编辑:如果要在具有最大值(第二个值)的所有元素中找到最大索引(第一个值),则可以这样做
>>> _, max_value = max(data, key=lambda item: item[1])
>>> max(index for index, value in data if value == max_value)
您可以在单个迭代中完成相同的操作,例如
max_index = float("-inf")
max_value = float("-inf")
for index, value in data:
if value > max_value:
max_value = value
max_index = index
elif value == max_value:
max_index = max(max_index, index)