数時間後、他の投稿からの提案がありましたが、問題を解決できませんでした。私は多くの辞書を管理しなければなりません (今まで私が知っている唯一の方法です)。
結合したい 4 つの辞書すべてについて、そのうちの 3 つが同じキー (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]}
4 番目のディクショナリは、メタデータを含む参照ファイルによって生成されたディクショナリであり、それらのキーは の 1 つの値に等しく、最終的なディクショナリにの情報を含む以降の情報を含むディクショナリ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行です。
深い知識がないため、簡単な提案 (ダミー用) をいただければ幸いです。