Heim >Backend-Entwicklung >Python-Tutorial >Wie kann ich verschachtelte Wörterbücher in Python tiefgreifend zusammenführen und Konflikte behandeln?

Wie kann ich verschachtelte Wörterbücher in Python tiefgreifend zusammenführen und Konflikte behandeln?

Linda Hamilton
Linda HamiltonOriginal
2024-12-04 22:55:141008Durchsuche

How Can I Deep Merge Nested Dictionaries in Python and Handle Conflicts?

Deep Merging Dictionaries of Dictionaries in Python

Bei der Arbeit mit komplexen Datenstrukturen ist es oft notwendig, mehrere Wörterbücher zusammenzuführen, um ein einheitliches zu erstellen Darstellung. Eine besondere Herausforderung entsteht, wenn die Wörterbücher verschachtelte Strukturen von Wörterbüchern enthalten, was als „Deep Merging“ bezeichnet wird.

Um diese Herausforderung zu bewältigen, können wir einen rekursiven Ansatz in Python nutzen. Die folgende Funktion führt Wörterbücher effektiv zusammen und behandelt Konflikte elegant:

def merge(a: dict, b: dict, path=[]):
    for key in b:
        if key in a:
            if isinstance(a[key], dict) and isinstance(b[key], dict):
                merge(a[key], b[key], path + [str(key)])
            elif a[key] != b[key]:
                raise Exception('Conflict at ' + '.'.join(path + [str(key)]))
        else:
            a[key] = b[key]
    return a

Im Falle widersprüchlicher Werte löst die Funktion eine Ausnahme aus.

Um die Verwendung zu veranschaulichen, betrachten Sie das folgende Beispiel:

dict1 = {1:{'a':{'A'}}, 2:{'b':{'B'}}}
dict2 = {2:{'c':{'C'}}, 3:{'d':{'D'}}}

Durch die Verwendung von merge(dict1, dict2) können wir das gewünschte Ergebnis erhalten:

{1:{'a':{'A'}}, 2:{'b':{'B'},'c':{'C'}}, 3:{'d':{'D'}}}

Dies Dieser Ansatz stellt sicher, dass die Verschachtelung innerhalb von Wörterbüchern effizient gehandhabt wird, was die tiefe Zusammenführung komplexer Datenstrukturen ermöglicht.

Das obige ist der detaillierte Inhalt vonWie kann ich verschachtelte Wörterbücher in Python tiefgreifend zusammenführen und Konflikte behandeln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn