我是Python的新手,并且遇到了以下代码的问题.
我正在寻找一种方法,可以按多个键分组并汇总/平均使用Python词典列表的值.下面的代码(也位于先前的问题/响应,位于:Group by multiple keys and summarize/average values of a list of dictionaries)使我处在正确的轨道上,但我遇到了在循环中添加更多字段聚合的问题.
假设我有一个字典列表,如下所示:
input = [
{'msn': '001', 'source': 'foo', 'status': '1', 'qty': 100, 'vol': 100},
{'msn': '001', 'source': 'bar', 'status': '2', 'qty': 200, 'vol': 200},
{'msn': '001', 'source': 'foo', 'status': '1', 'qty': 300, 'vol': 300},
{'msn': '002', 'source': 'baz', 'status': '2', 'qty': 400, 'vol': 100},
{'msn': '002', 'source': 'baz', 'status': '1', 'qty': 500, 'vol': 400},
{'msn': '002', 'source': 'qux', 'status': '1', 'qty': 600, 'vol': 100},
{'msn': '003', 'source': 'foo', 'status': '2', 'qty': 700, 'vol': 200}]
到目前为止,我的代码:
for key, grp in groupby(sorted(dict_list, key = grouper), grouper):
temp_dict = dict(zip(["msn", "source"], key))
temp_dict["qty"] = sum(item["qty"] for item in grp)
temp_dict["vol"] = sum(item["vol"] for item in grp)
result.append(temp_dict)
预期结果是:
{'msn': '001', 'source': 'foo', 'qty': 400, 'vol': 400},
{'msn': '001', 'source': 'bar', 'qty': 200, 'vol': 200},
{'msn': '002', 'source': 'baz', 'qty': 200, 'vol': 500},
{'msn': '003', 'source': 'foo', 'qty': 900, 'vol': 200}]
在temp循环中放置temp_dict [“ vol”] = sum(grp中的item [item [“ vol”])不会产生所需的结果,这最终是我的问题.
在添加(附加)另一个字段及其计算值到列表中的同时,如何保存键,如代码中所示分组?
在此先感谢您的帮助.