Объединить несколько словарей по ключам и значениям?
После часов и предложений из других постов, я не мог решить свою проблему. Я должен управлять многими словарями (до сих пор единственный способ, которым я знаю, чтобы работать).
Для всех четырех словарей, которые я хочу объединить, три из них имеют одинаковый ключ (d1, d2 и d3).
d1 = {key1: [x1, x2, x3], key2: [y1, y2, y3], key3: [z1, z2, z3]}
d2 = {key1: [x4, x5, x6],key2: [y4, y5, y6], key3: [z4, z5, z6]}
d3 = {key1: [x7, x8, x9], key2: [y7, y8, y9], key3: [z7, z8, z9]}
d4 = {x2: [a, b, c], y2: [d, e, f], z2: [g, h, i]}
Четвертый словарь представляет собой словарь, сгенерированный справочным файлом, содержащим метаданные, и их ключи равны одному значению в d1
и я хочу создать словарь с информацией из d1, d2
а также d3
и после включения информации d4
в последнем словаре.
final_dict = {key1: [x1, a, b, x2, x3, x4, x5, x8, x9],
key2: [y1, d, e, y2, y3, y4, y5, y8, y9],
key3: [z1, g, h, z2, z3, z4, z5, z8, z9]}
и напечатать так в табличном формате:
key1 x1 a b x2 x3 x4 x5 x8 x9
key2 y1 d e y2 y3 y4 y5 y8 y9
key3 z1 g h z2 z3 z4 z5 z8 z9
На данный момент у меня есть грязный сценарий, но "работает".
#!/usr/bin/env python
with open("file1.txt", "r") as file1, open("file2.txt", "r") as file2, /
open("file3.txt", "r") as file3, open("file4.txt", "r") as file4:
d1 = {}
d2 = {}
d3 = {}
d4 = {}
dicts = [d1, d2, d3, d4]
#d1 = {key1: [x1, x2, x3], key2: [y1, y2, y3], key3: [z1, z2, z3]}
#d2 = {key1: [x4, x5, x6],key2: [y4, y5, y6], key3: [z4, z5, z6]}
#d3 = {key1: [x7, x8, x9], key2: [y7, y8, y9], key3: [z7, z8, z9]}
#d4 = {x2: [a, b, c], y2: [d, e, f], z2: [g, h, i]}
for b in file1:
row = b.strip().split('\t')
if row[0] not in d1:
d1[row[0]] = row[1], row[3], row[4]
for c in file2:
row = c.strip().split('\t')
if row[0] not in d2:
d2[row[0]] = row[1:]
for f in file3:
row = f.strip().split('\t')
if row[0] not in d3:
d3[row[0]] = row[1:]
for m in file4:
row = m.strip().split('\t')
if row[0] not in d4:
d4[row[0]] = row[1], row[3], row[2]
final_dict = {}
for k in (dicts):
for key, value in k.iteritems():
final_dict[key].append(value)
print final_dic
#key1 x1 a b x2 x3 x4 x5 x8 x9
#key2 y1 d e y2 y3 y4 y5 y8 y9
#key3 z1 g h z2 z3 z4 z5 z8 z9
Проблема в последних 3 строчках.
Из-за отсутствия глубоких знаний, простые предложения (для чайников) будут оценены.
1 ответ
Я думаю, что это то, что вы ищете, хотя логика относительно того, почему переменные, как x6
, x7
, y6
, y7
и т. д. были исключены пока непонятно
Во-первых, сделайте эти переменные (например, x1
, x2
и т. д.) существуют, и присваивают свое имя в виде строки для их значений, чтобы упростить отслеживание результатов позже:
values = [letter + str(number) for letter in 'xyz' for number in range(1, 10)] + ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i']
for v in values:
exec('%s = "%s"' % (v, v))
Далее давайте создадим экземпляры ваших словарей:
d1 = {key1: [x1, x2, x3], key2: [y1, y2, y3], key3: [z1, z2, z3]}
d2 = {key1: [x4, x5, x6],key2: [y4, y5, y6], key3: [z4, z5, z6]}
d3 = {key1: [x7, x8, x9], key2: [y7, y8, y9], key3: [z7, z8, z9]}
d4 = {x2: [a, b, c], y2: [d, e, f], z2: [g, h, i]}
Тогда давайте объединим словари в один большой dict
:
new_dict = {}
for d in [d1, d2, d3]:
for key in d:
if key not in new_dict:
# if key not yet in the dict, make it so
new_dict[key] = d[key]
else:
# if key already there, then we'll just add the lists together
new_dict[key] += d[key]
И, наконец, получить первые два отдельных письма от d4
мы можем попробовать это:
for key in new_dict:
for other_key in d4:
if other_key in new_dict[key]:
new_dict[key] += d4[other_key][:2]
Проверьте вывод:
>>> new_dict
{'key2': ['y1', 'y2', 'y3', 'y4', 'y5', 'y6', 'y7', 'y8', 'y9', 'd', 'e'], 'key3': ['z1', 'z2', 'z3', 'z4', 'z5', 'z6', 'z7', 'z8', 'z9', 'g', 'h'], 'key1': ['x1', 'x2', 'x3', 'x4', 'x5', 'x6', 'x7', 'x8', 'x9', 'a', 'b']}
Это в основном ваш желаемый результат, за исключением того, что включает в себя 6 и 7. Можете ли вы дать некоторое представление о том, почему ваш желаемый результат выглядит именно так? Во всяком случае, это должно начать вас.