使用多个键和每个键的多个值过滤字典

时间:2016-08-18 18:48:51

标签: list python-2.7 dictionary openxls

我有一个关于如何使用循环过滤字典的问题。

以下是字典的示例:

d = {'beta': ['ABC', '1', '5', '10', '15'],
     'lambda': ['DEF', '3', '30', '22.2', '150'],
     'omega': ['RST','15', '54.4', '150', '75']
}

如果每个键中的第3个值是<

如何过滤字典以删除键。 100?换句话说,在if函数之后,只有omega应该留在字典中 我试过了:

for k, v in d.iteritems(): 
    r = float((d[key][2]))
    if r < float(100):
        del d[k]

但它没有用。有什么想法吗?这里是python编程的新手。

新词典应该保留omega键,因为150大于100。

1 个答案:

答案 0 :(得分:0)

def cast_values(v):
    try:
        return float(v)
    except ValueError:
        return v

new_d = {k:[ cast_values(i) for i in v ] for k,v in d.items() if float(v[3]) > 100}

结果:

new_d = {'omega': ['RST', 15, 54.4, 150, 75]}