25

我在 Python 中有两个字典:

d1 = {'a': 10, 'b': 9, 'c': 8, 'd': 7}
d2 = {'a': 1, 'b': 2, 'c': 3, 'e': 2}

我想在字典 d1-d2 之间减去值并得到结果:

d3 = {'a': 9, 'b': 7, 'c': 5, 'd': 7 }

现在我使用两个循环,但这个解决方案不是太快

for x,i in enumerate(d2.keys()):
        for y,j in enumerate(d1.keys()):
4

4 回答 4

38

我认为一种非常 Pythonic 的方式是使用dict comprehension

d3 = {key: d1[key] - d2.get(key, 0) for key in d1}

请注意,这只适用于 Python 2.7+ 或 3。

于 2013-07-16T08:57:36.333 回答
25

如果collections.Counter已知所有结果​​值都是严格正数,则使用 。语法非常简单:

>>> from collections import Counter
>>> d1 = Counter({'a': 10, 'b': 9, 'c': 8, 'd': 7})
>>> d2 = Counter({'a': 1, 'b': 2, 'c': 3, 'e': 2})
>>> d3 = d1 - d2
>>> print d3
Counter({'a': 9, 'b': 7, 'd': 7, 'c': 5})

请注意,如果不是所有值都被认为是严格为正的:

  • 结果中将省略值为零的元素
  • 值变为负数的元素将丢失,或被错误值替换。例如,print(d2-d1)可以屈服Counter({'e': 2})
于 2013-07-16T08:45:52.963 回答
14

只是 Haidro 答案的更新。

建议使用减法代替“-”。

d1.减法(d2)

使用 - 时,仅将正数计数器更新到字典中。请参阅下面的示例

c = Counter(a=4, b=2, c=0, d=-2)
d = Counter(a=1, b=2, c=3, d=4)
a = c-d
print(a)        # --> Counter({'a': 3})
c.subtract(d)
print(c)        # --> Counter({'a': 3, 'b': 0, 'c': -3, 'd': -6})

请注意,使用减法时字典会更新。

最后使用 dict(c) 从 Counter 对象中获取 Dictionary

于 2013-07-16T08:59:07.220 回答
4

Haidro 发布了一个简单的解决方案,但即使没有collections你也只需要一个循环:

d1 = {'a': 10, 'b': 9, 'c': 8, 'd': 7}
d2 = {'a': 1, 'b': 2, 'c': 3, 'e': 2}
d3 = {}

for k, v in d1.items():
    d3[k] = v - d2.get(k, 0) # returns value if k exists in d2, otherwise 0

print(d3) # {'c': 5, 'b': 7, 'a': 9, 'd': 7}
于 2013-07-16T08:49:23.690 回答