加入非唯一的第二个id - Python

时间:2017-08-10 15:50:34

标签: python dictionary

我正在尝试将字典加入另一个字典。我有两把钥匙;一个是独特的,另一个不是唯一的。我想加入关于非唯一密钥的信息并保留所有信息,因为它是唯一密钥,即唯一ID的数量必须保持不变。

有关如何实现这一目标的任何想法?

这是第一本字典:

    names = [
    {'id': '1', 'name': 'Peter', 'category_id': '25'}, 
    {'id': '2', 'name': 'Jim', 'category_id': '20'}, 
    {'id': '3', 'name': 'Toni', 'category_id': '20'}
]

这是第二本字典:

categories = [
    {'category_id': '25', 'level': 'advanced'}, 
    {'category_id': '20', 'level': 'beginner'}
]

这就是我想要实现的目标:

all = [
    {'id': '1', 'name': 'Peter', 'category_id': '25', 'level': 'advanced'}, 
    {'id': '2', 'name': 'Jim', 'category_id': '20', 'level': 'beginner'}, 
    {'id': '3', 'name': 'Toni', 'category_id': '20', 'level': 'beginner'}
]

编辑:

names = [
    {'id': '1', 'name': 'Peter', 'category_id': '25'}, 
    {'id': '2', 'name': 'Jim', 'category_id': '20'}, 
    {'id': '3', 'name': 'Toni', 'category_id': '20'}
]

categories = [
    {'category_id': '25', 'level': 'advanced'}, 
    {'category_id': '20', 'level': 'beginner'}
]

def merge_lists(l1, l2, key):
    merged = {}
    for item in l1+l2:
        if item[key] in merged:
            merged[item[key]].update(item)
        else:
            merged[item[key]] = item
    return merged.values()

courses = merge_lists(names, categories, 'category_id')
print(courses)

给出:

([{'id': '1', 'name': 'Peter', 'category_id': '25', 'level': 'advanced'}, 
{'id': '3', 'name': 'Toni', 'category_id': '20', 'level': 'beginner'}])

2 个答案:

答案 0 :(得分:3)

创建从category_id到其他字段的映射,然后在循环中组合字典,例如:

cat = {d["category_id"]: d for d in categories}
res = []

for name in names:
    x = name.copy()
    x.update(cat[name["category_id"]])  
    res.append(x)

在Python 3.5+中,您可以使用很酷的新语法:

cat = {d["category_id"]: d for d in categories}
res = [{**name, **cat[name["category_id"]]} for name in names]

答案 1 :(得分:1)

考虑您真正想做的事情:将与每个类别相关联的级别添加到names dict。首先,创建从类别到关联级别的映射:

cat_dict = {d['category_id']: d['level'] for d in categories}

然后对names列表中的每个字典进行一次微不足道的转换:

for d in names:
    d['level'] = cat_dict[d['category_id']]

生成的names列表是:

[{'category_id': '25', 'id': '1', 'level': 'advanced', 'name': 'Peter'},
 {'category_id': '20', 'id': '2', 'level': 'beginner', 'name': 'Jim'},
 {'category_id': '20', 'id': '3', 'level': 'beginner', 'name': 'Toni'}]