如何更新字典,以便如果键'a'的值为'c'而不是'c'的键,则附加值'a'?

问题描述 投票:0回答:2

如果密钥'a'的值为'c',则'c'的密钥应附加'a'。请注意,与密钥'a'关联的值不包含在附加中。

我似乎无法弄清楚如何自动执行此过程以在大型字典上执行。

mydict = {
'a': ['z', 'c'],
'b': ['y', 'c'],
'c': ['q', 'r']
}

这是我想要的结果:

mydict = {
'a': ['z', 'c'],
'b': ['y', 'c'],
'c': ['q', 'r', 'a', 'b']
}
python loops dictionary key-value
2个回答
0
投票

这是另一种方法,使用集合交集,以及保持父/子关系的中间映射。

from collections import defaultdict

d = defaultdict(list)

keys = set([*mydict])

for k, v in mydict.items():
    intersected = keys & set(v)
    for i in intersected:
        d[i].append(k)

print(d)
# defaultdict(list, {'c': ['b', 'a']})

for found, value in d.items():
    mydict[found].extend(value)

print(mydict)
# {'a': ['z', 'c'], 'b': ['y', 'c'], 'c': ['q', 'r', 'b', 'a']}

-1
投票
for k in mydict:
    for val in mydict[k]:
        if val in mydict:
            mydict[val] += [k]
© www.soinside.com 2019 - 2024. All rights reserved.