在python中的字典列表中查找最小值

2024-08-10Python开发问题
3

本文介绍了在python中的字典列表中查找最小值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我要查找并返回字符串中id的最小值,例如:

find_min_id([{"nonid": "-222", "id": 0}, {"id": -101}])
-101
find_min_id([{’id’: 63, 'id': 42}])
42

到目前为止我有这个:

def find_min_id(list):
    return min(list)

但这意味着:

{'id': -101}

并且我只需要最低ID的值。

推荐答案

使用minkey参数:

def find_min_id(l):
    return min(l, key=lambda d: d.get("id", float('inf')))["id"]

这实际上会查找最小ID,并且无需创建新列表即可执行此操作。

唯一的问题是,列表中的元素可能没有'id'键。为此,我不得不使用.get("id", float('inf'))。因此,如果没有id键,该函数将返回inf,这可能不是我们所希望的。当给定一个空列表时,min()所做的是抛出一个异常,所以如果我们传递给它的所有判据都没有'id'键,我们可能也会这样做。在这种情况下,生成器调用的最小值可能确实更好:

def find_min_id(l):
    return min(d["id"] for d in l if "id" in d)

另一种方法是检查min的结果是否为inf,但这比较麻烦:

import math
def find_min_id(l):
    res = min(l, key=lambda d: d.get("id", float('inf')))["id"]
    if math.isinf(res):
        raise ValueError("No dict has an 'id' key")
    return res

这篇关于在python中的字典列表中查找最小值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

在xarray中按单个维度的多个坐标分组
groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)...
2024-08-22 Python开发问题
15

Pandas中的GROUP BY AND SUM不丢失列
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)...
2024-08-22 Python开发问题
17

pandas 有从特定日期开始的按月分组的方式吗?
Is there a way of group by month in Pandas starting at specific day number?( pandas 有从特定日期开始的按月分组的方式吗?)...
2024-08-22 Python开发问题
10

GROUP BY+新列+基于条件的前一行抓取值
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)...
2024-08-22 Python开发问题
18

PANDA中的Groupby算法和插值算法
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)...
2024-08-22 Python开发问题
11

PANAS-基于列对行进行分组,并将NaN替换为非空值
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)...
2024-08-22 Python开发问题
10