我有以下元组列表
[
('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文件,因此这次转换将完成多次,并且需要最有效的解决方案
你需要学习如何提问。你应该向我们展示你的尝试和你做了什么。您应该自己尝试编写算法...
幸运的是,我在办公室工作,所以我只是为你破解了一个解决方案..试试看看它是否有效:
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)
祝好运下次!