Python词典列表 - 添加具有相同键名的词组

时间:2018-04-18 09:15:37

标签: python list dictionary iteration

我有一个像这样的python列表:

user = [
        {'name': 'ozzy', 'quantity': 5},
        {'name': 'frank', 'quantity': 4},
        {'name': 'ozzy', 'quantity': 3},
        {'name': 'frank', 'quantity': 2},
        {'name': 'james', 'quantity': 7},
        ]

我正在尝试编写代码以通过添加数量来加入具有相同名称的词典。最终的清单是:

user = [
        {'name': 'ozzy', 'quantity': 8},
        {'name': 'frank', 'quantity': 6},
        {'name': 'james', 'quantity': 7}
        ]

我尝试了一些方法,但我正在努力获得正确的代码。我在下面写的代码有点添加了值(实际上我的列表更长,我刚刚添加了一小部分供参考)。

newList = []
    quan = 0
    for i in range(0,len(user)):      
        originator = user[i]['name']
        for j in range(i+1,len(user)):
            if originator == user[j]['name']:
                quan = user[i]['quantity'] + user[j]['quantity']
                newList.append({'name': originator, 'Quantity': quan})
你可以帮我找到正确的代码吗?

5 个答案:

答案 0 :(得分:5)

只需计算collections.Counter中的项目,然后根据需要展开回到词典列表:

user = [
        {'name': 'ozzy', 'quantity': 5},
        {'name': 'frank', 'quantity': 4},
        {'name': 'ozzy', 'quantity': 3},
        {'name': 'frank', 'quantity': 2},
        {'name': 'james', 'quantity': 7},
        ]

import collections

d = collections.Counter()
for u in user:
    d[u['name']] += u['quantity']

print(dict(d))

newlist = [{'name' : k, 'quantity' : v} for k,v in d.items()]

print(newlist)
首先输出Counter dict,这已经足够了:

{'frank': 6, 'ozzy': 8, 'james': 7}

并使用dicts列表重新格式化输出:

[{'name': 'frank', 'quantity': 6}, {'name': 'ozzy', 'quantity': 8}, {'name': 'james', 'quantity': 7}]

答案 1 :(得分:1)

使用标准字典,解决方案也很简单。这里不需要CounterOrderedDict

user = [
        {'name': 'ozzy', 'quantity': 5},
        {'name': 'frank', 'quantity': 4},
        {'name': 'ozzy', 'quantity': 3},
        {'name': 'frank', 'quantity': 2},
        {'name': 'james', 'quantity': 7},
        ]

dic = {}
for item in user:
  n, q = item.values()
  dic[n] = dic.get(n,0) + q
print(dic)

user = [{'name':n, 'quantity':q} for n,q in dic.items()]
print(user)

结果:

{'ozzy': 8, 'frank': 6, 'james': 7}
[{'name': 'ozzy', 'quantity': 8}, {'name': 'frank', 'quantity': 6}, {'name': 'james', 'quantity': 7}]

答案 2 :(得分:0)

我建议改变输出字典的外观,使其实际可用。考虑这样的事情

user = [
        {'name': 'ozzy', 'quantity': 5},
        {'name': 'frank', 'quantity': 4},
        {'name': 'ozzy', 'quantity': 3},
        {'name': 'frank', 'quantity': 2},
        {'name': 'james', 'quantity': 7},
        ]

data = {}
for i in user:
    print(i)
    if i['name'] in data:
        data[i['name']] += i['quantity']
    else:
        data.update({i['name']: i['quantity']})

print(data)
  

{' frank':6,' james':7,' ozzy':8}

答案 3 :(得分:0)

如果您需要保持原始相对顺序:

from collections import OrderedDict

user = [
        {'name': 'ozzy', 'quantity': 5},
        {'name': 'frank', 'quantity': 4},
        {'name': 'ozzy', 'quantity': 3},
        {'name': 'frank', 'quantity': 2},
        {'name': 'james', 'quantity': 7},
        ]

d = OrderedDict()
for item in user:
    d[item['name']] = d.get(item['name'], 0) + item['quantity']

newlist = [{'name' : k, 'quantity' : v} for k, v in d.items()]
print(newlist)

输出:

[{'name': 'ozzy', 'quantity': 8}, {'name': 'frank', 'quantity': 6}, {'name': 'james', 'quantity': 7}]

答案 4 :(得分:0)

user = [
    {'name': 'ozzy', 'quantity': 8},
    {'name': 'frank', 'quantity': 6},
    {'name': 'james', 'quantity': 7}
]

reference_dict = {}

for item in user :
    reference_dict[item['name']] = reference_dict.get(item['name'],0) + item['quantity']

#Creating new list from reference dict
updated_user = [{'name' : k , 'quantity' : v} for k,v in reference_dict.items()]

print updated_user