将元组列表合并到字典中

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

我有以下元组列表

[
('A-1', 'B-1', 'C'), 
('A-1', 'B-2', 'D'), 
('A-1', 'B-3', 'E'), 
('A-1', 'B-4', 'F'), 
('A-1', 'B-5', 'G')
]

我想创建以下字典词典:

{A:{"A-1":{"B":{"B-1":"C","B-2":"D","B-3":"E","B-4":"F","B-5":"G"}}}}

什么是最好的选择?我必须从bbdd中提取数据并生成一个JSON文件,因此这次转换将完成多次,并且需要最有效的解决方案

python json list dictionary tuples
1个回答
2
投票

你需要学习如何提问。你应该向我们展示你的尝试和你做了什么。您应该自己尝试编写算法...

幸运的是,我在办公室工作,所以我只是为你破解了一个解决方案..试试看看它是否有效:

def convert_function(input):
    output = {}
    for val in input:
        first_dict = output.get(val[0][0], {})
        second_dict = first_dict.get(val[0], {})
        third_dict = second_dict.get(val[1][0], {})

        third_dict[val[1]] = val[2]
        second_dict[val[1][0]] = third_dict
        first_dict[val[0]] = second_dict

        output[val[0][0]] = first_dict
    return output

input = [
    ('A-1', 'B-1', 'C'), 
    ('A-1', 'B-2', 'D'), 
    ('A-1', 'B-3', 'E'), 
    ('A-1', 'B-4', 'F'), 
    ('A-1', 'B-5', 'G')
]

print convert_function(input)

祝好运下次!

© www.soinside.com 2019 - 2024. All rights reserved.