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!