6

这真的很容易用一个例子来解释,所以要从 dict 中删除列表的交集,我通常会这样做:

a = {1:'', 2:'', 3:'', 4:''}
exclusion = [3, 4, 5]

# have to build up a new list or the iteration breaks
toRemove = []
for var in a.iterkeys():
    if var in exclusion:
        toRemove.append(var)

for var in toRemove:
    del a[var]

这似乎是一个不寻常的例子,但令人惊讶的是我不得不做这样的事情的次数。使用集合执行此操作会更好,但我显然想保留字典的“值”。

这种方法很烦人,因为它需要两个循环和一个额外的数组。有没有一种更清洁、更有效的方法来做到这一点。

4

4 回答 4

14

考虑dict.pop

for key in exclusion:
     a.pop(key, None)

当不是关键时,None保持弹出不会引发异常。key

于 2008-10-03T14:28:29.043 回答
3
a = dict((key,value) for (key,value) in a.iteritems() if key not in exclusion)
于 2008-10-03T14:34:20.917 回答
2

为什么不直接使用keys方法,而不是iterkeys? 这样你就可以在一个循环中完成它,因为它返回一个列表,而不是一个迭代器。

于 2008-10-03T14:32:12.547 回答
1

您可以将排除列表更改为一组,然后只需使用交集来获得重叠。

exclusion = set([3, 4, 5])

for key in exclusion.intersection(a):
    del a[key]
于 2008-10-03T15:09:12.143 回答