簡體   English   中英

如何將dicts列表與內部列表連接起來

[英]How to concatenate a list of dicts with inner lists

我有一個帶有內部列表和dicts的dicts列表,我需要在一個大的dict中連接它們。 列表是這樣的:

[{'total': {'last_day': '7'}}, 
 {'total': {'progress': '07/04'}}, 
 {'total': {'piecies': '3008'}}, 
 {'total': {'week': ['16.0']}}, 
 {'total': {'week': ['17.0']}}, 
 {'total': {'week': ['15.0']}}, 
 {'total': {'week': ['17.0']}}, 
 {'total': {'week': ['16.0']}}, 
 {'total': {'week': ['13.0']}}, 
 {'total': {'week': ['6.0']}}, 
 {'tkts': [{'tktvalue': '13.5'}]}, 
 {'tkts': [{'month': {'consuntivato_pezzi': '2346'}}]}, 
 {'tkts': [{'month': {'consuntivato_euro': '31671.00'}}]}, 
 {'tkts': [{'month': {'preventivato_pezzi': '9897'}}]}
]

我嘗試了一些for循環和遞歸函數,沒有很好的結果

for vars in temporary_var:
    for title in vars:
        try:
            try:
                table_var[title].update(vars[title])
            except KeyError:
                table_var[title] = vars[title]
        except AttributeError:
            table_var[title].append(vars[title][0])

但我只能得到這個:

{'total': {'last_day': '7', 'progress': '07/04', 'volumes': '3008', 'week': ['6.0']}, 'tkts': [{'service': 'SOSPC'}, {'tktvalue': '13.5'}, {'month': {'volumes1': '2346'}}, {'month': {'volumes2': '31671.00'}}, {'month': {'volumes3': '98
97'}}]}

但我需要這個:

{'total': {'last_day': '7', 'progress': '07/04', 'volumes': '3008', 'week': ['16.0', '17.0', '15.0', '17.0', '16.0', '13.0','6.0']}, 'tkts': [{'service': 'SOSPC', 'tktvalue': '13.5', 'month': {'volumes1': '2346', 'volumes2': '31671.00', 'volumes3': '9897'}}]}

試試這個,它獲得你想要的輸出:


lst=[{'total': {'last_day': '7'}},
 {'total': {'progress': '07/04'}},
 {'total': {'piecies': '3008'}},
 {'total': {'week': ['16.0']}},
 {'total': {'week': ['17.0']}},
 {'total': {'week': ['15.0']}},
 {'total': {'week': ['17.0']}},
 {'total': {'week': ['16.0']}},
 {'total': {'week': ['13.0']}},
 {'total': {'week': ['6.0']}},
 {'tkts': [{'tktvalue': '13.5'}]},
 {'tkts': [{'month': {'consuntivato_pezzi': '2346'}}]},
 {'tkts': [{'month': {'consuntivato_euro': '31671.00'}}]},
 {'tkts': [{'month': {'preventivato_pezzi': '9897'}}]}
]

d={} # the dictionary that will hold the result

for dd in lst: # for each dictionary in the list of dictionaries
    for key,value in dd.items():
        if key not in d: # key does not exist in dictionary d
            d[key]=value

        else: # key exists in dictionary d
            if isinstance(value,dict): # check if the value is a dictionary or a list
                for key1,value2 in value.items():
                    if key1 not in d[key]:
                        d[key]={**d[key],**value} # combine the dictionaries
                    else:
                        d[key][key1].append(value2[0])

            elif isinstance(value,list): # check if the value is a  list
                if isinstance(value[0],dict): # check if the value is a dictionary or a list
                    for key1,value2 in value[0].items():
                        if key1 not in d[key][0]:
                            d[key][0]={**d[key][0],**value[0]}
                        else:
                            d[key][0][key1]={**d[key][0][key1],**value2}

print(d)



輸出:{'total':{'last_day':'7','progress':'07 / 04','piecies':'3008','week':['16 .0','17 .0','15 .0' ,'17 .0','16 .0','13 .0','6.0']},'tkts':[{'tktvalue':'13 .5','month':{'consuntivato_pezzi':'2346','consuntivato_euro': '31671.00','preventivato_pezzi':'9897'}}]}

嘗試使用默認列表。 您可以了解有關他們collections.defaultdict的更多信息

from collections import defaultdict
result = defaultdict(list)
for sequence in (yourdict):
    for keys,dictionary in sequence.items():
          result[keys].append(dictionary)


print(dict(result))

輸出:

{'total': [{'last_day': '7'}, {'progress': '07/04'}, {'piecies': '3008'}, {'week': ['16.0']}, {'week': ['17.0']}, {'week': ['15.0']}, {'week': ['17.0']}, {'week': ['16.0']}, {'week': ['13.0']}, {'week': ['6.0']}], 'tkts': [[{'tktvalue': '13.5'}], [{'month': {'consuntivato_pezzi': '2346'}}], [{'month': {'consuntivato_euro': '31671.00'}}], [{'month': {'preventivato_pezzi': '9897'}}]]}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM