Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Menggabungkan Kamus Berbilang Aras secara Rekursif dalam Python?

Bagaimanakah Saya Boleh Menggabungkan Kamus Berbilang Aras secara Rekursif dalam Python?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-04 20:42:11359semak imbas

How Can I Recursively Merge Multi-Level Dictionaries in Python?

Menggabungkan Kamus Berbilang Aras Dengan Mendalam

Dalam Python, menggabungkan kamus secara rekursif sambil mengekalkan kedalaman sarang yang tidak diketahui boleh menjadi satu cabaran. Berikut ialah penyelesaian yang menangani isu ini:

def deep_merge(a: dict, b: dict, path=[]):
    for key in b:
        if key in a:
            if isinstance(a[key], dict) and isinstance(b[key], dict):
                deep_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

Fungsi ini mengambil dua kamus sebagai input dan menggabungkan kandungannya secara rekursif. Ia mengekalkan laluan untuk menjejak tahap sarang semasa untuk memberikan mesej ralat yang lebih tepat sekiranya berlaku konflik.

Contoh:

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

print(result)
# {1:{'a':{'A'}}, 2:{'b':{'B'}, 'c':{'C'}}, 3:{'d':{'D'}}}

Perhatikan bahawa deep_merge memutasi hujah pertama, itulah sebabnya keputusan mengandungi kamus gabungan.

Untuk menggabungkan berbilang kamus tanpa mengubah suai mana-mana daripadanya, hantarkannya sebagai kata kunci hujah:

from functools import reduce
result = reduce(deep_merge, [dict1, dict2, ...], {})

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggabungkan Kamus Berbilang Aras secara Rekursif dalam Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn