获得字典中的最大键但低于变量

时间:2013-04-14 17:34:56

标签: python

给出一个字典和这样的变量:

dic = {0 : 'some', 10 : 'values', 20 : 'whatever'}
var = 14

我想从字典中获取密钥最大但低于或等于变量的值。我不知道这是否清楚,但在这种情况下,我正在寻找10

我已经提出了这个功能,但我想知道是否有一种更简单的方法可以做到这一点,因为我对python很新。

def get_greatest_key(dic, var):
    # if the key exists no need to search
    if var in dic:
        return dic[var]
    else:
        # create a list with all the keys sorted in reverse 
        l = sorted(dic, key=dic.get)
        i = 0
        while i < len(l):
            # parse the list
            if l[i] <= var:
                return dic[l[i]]
            i += 1
        # by default we return the last element in the dictionary
        return dic[l[len(l) - 1]]

1 个答案:

答案 0 :(得分:8)

如果您希望最大键小于或等于var,则可以将生成器表达式传递给max函数:

>>> dic = {0 : 'some', 10 : 'values', 20 : 'whatever'}
>>> var = 14
>>> max(k for k in dic if k <= var)
10

具有相应的值

>>> dic[max(k for k in dic if k <= var)]
'values'

如果您认为合适的ValueError参数为空,您可以决定如何处理max抛出的内容。