gpt4 book ai didi

python - 基于多键或多键组合或合并字典

转载 作者:太空狗 更新时间:2023-10-30 02:53:19 25 4
gpt4 key购买 nike

我整个上午都在搜索,但大多数合并示例仅基于一个键,我在多个键上找不到任何东西。

x = [
{'pid':111, 'sid':6, 'eid':123, 'x_qty':30},
{'pid':222, 'sid':56, 'eid':6212, 'x_qty':2}
]

y = [
{'pid':111, 'sid':6, 'eid':123, 'y_qty':123},
{'pid':333, 'sid':56, 'eid':6212, 'y_qty':112}
]

pid=111、sid=6、eid=123 的值在 x 和 y 中都匹配,然后合并为一条记录。如果它们不匹配,就按原样拿过来。

我想要的最终结果:

z = [
{'pid': 111, 'sid': 6, 'eid': 123, 'x_qty': 30, 'y_qty': 123},
{'pid': 222, 'sid': 56, 'eid': 6212, 'x_qty': 2},
{'pid': 333, 'sid': 56, 'eid': 6212, 'y_qty': 112}
]

最佳答案

这是重新键入一个元组:

>>> from operator import itemgetter
>>> from collections import defaultdict
>>> data = defaultdict(dict)
>>> f = itemgetter('pid', 'sid', 'eid')
>>> for d in [*x, *y]:
... data[f(d)].update(d)
...
>>> list(data.values())
[{'eid': 123, 'pid': 111, 'sid': 6, 'x_qty': 30, 'y_qty': 123},
{'eid': 6212, 'pid': 222, 'sid': 56, 'x_qty': 2},
{'eid': 6212, 'pid': 333, 'sid': 56, 'y_qty': 112}]

关于python - 基于多键或多键组合或合并字典,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50051890/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com