Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Mencantumkan Kamus Bersarang dalam Python dan Mengendalikan Konflik?

Bagaimanakah Saya Boleh Mencantumkan Kamus Bersarang dalam Python dan Mengendalikan Konflik?

Linda Hamilton
Linda Hamiltonasal
2024-12-04 22:55:141245semak imbas

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

Kamus Penggabungan Mendalam bagi Kamus dalam Python

Apabila bekerja dengan struktur data yang kompleks, sering kali menjadi perlu untuk menggabungkan berbilang kamus untuk mencipta satu gabungan perwakilan. Satu cabaran tertentu timbul apabila kamus mengandungi struktur kamus bersarang, yang dirujuk sebagai "penggabungan mendalam."

Untuk menangani cabaran ini, kami boleh memanfaatkan pendekatan rekursif dalam Python. Fungsi berikut menggabungkan kamus dengan berkesan sambil mengendalikan konflik dengan anggun:

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

Dalam kes nilai bercanggah, fungsi akan menimbulkan pengecualian.

Untuk menggambarkan penggunaan, pertimbangkan contoh berikut:

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

Dengan menggunakan merge(dict1, dict2), kita boleh mendapatkan yang diingini hasil:

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

Pendekatan ini memastikan bahawa sarang dalam kamus dikendalikan dengan cekap, membolehkan penggabungan mendalam struktur data kompleks.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencantumkan Kamus Bersarang dalam Python dan Mengendalikan Konflik?. 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