Dalam senario pengaturcaraan ini, matlamat kami adalah untuk melintasi struktur kamus yang berpotensi berbilang lapisan dan mencetak pasangan nilai kunci di mana nilainya berada bukan kamus bersarang sendiri. Jika nilai menjadi kamus bersarang, kita perlu meneroka secara rekursif dan mencetak pasangan nilai kuncinya juga.
Untuk mencapai ini, teknik lelaran mudah mungkin tidak mencukupi. Sebaliknya, kita boleh memanfaatkan kuasa rekursi. Berikut ialah fungsi yang disemak yang menggabungkan rekursi untuk mengendalikan kamus bersarang dengan berkesan pada sebarang kedalaman:
def myprint(d): for k, v in d.items(): if isinstance(v, dict): myprint(v) else: print("{0} : {1}".format(k, v))
Dengan memanggil myprint dengan kamus awal, fungsi memasuki gelung rekursif. Ia melawati setiap pasangan nilai kunci dan menyemak sama ada nilai itu ialah kamus. Jika ya, fungsi itu memanggil dirinya sendiri dengan kamus nilai sebagai input baharu, dengan berkesan menggerudi ke mana-mana tahap bersarang.
Jika nilai itu bukan kamus, fungsi hanya mencetak pasangan nilai kunci semasa. Proses ini berterusan sehingga semua peringkat kamus telah dilalui.
Berikut ialah demonstrasi menggunakan sampel kamus bersarang:
d = { "xml": { "config": { "portstatus": {"status": "good"}, "target": "1", }, "port": "11", } } myprint(d)
Ini akan menghasilkan output yang diingini:
xml : {config: {portstatus: {status: good}, target: 1}, port: 11} config : {portstatus: {status: good}, target: 1} portstatus : {status: good} status : good target : 1 port : 11
Seperti yang anda lihat, fungsi ini berulang secara berulang melalui kamus, mencetak semua nilai tidak bersarang dan menggerudi ke dalam bersarang kamus sehingga sampai ke nod daun.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengulang dan Mencetak Pasangan Nilai Kunci daripada Kamus Bersarang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!