Rumah > pembangunan bahagian belakang > Tutorial Python > Mengapa Fungsi Python Rekursif Saya Tiada Kembali Apabila Mencari Fail dalam Kamus Bersarang?

Mengapa Fungsi Python Rekursif Saya Tiada Kembali Apabila Mencari Fail dalam Kamus Bersarang?

Mary-Kate Olsen
Lepaskan: 2024-11-16 08:29:02
asal
655 orang telah melayarinya

Why Does My Recursive Python Function Return None When Searching for a File in a Nested Dictionary?

Fungsi Rekursif Mengembalikan Tiada dalam Python

Soalan

Dalam kod Python yang disediakan, fungsi rekursif bernama get_path sedang cuba mencari fail ( rqfile) dalam kamus bersarang (kamus). Walau bagaimanapun, apabila laluan ke fail ditemui dan perlu dikembalikan, fungsi mengembalikan Tiada. Kodnya adalah seperti berikut:

def get_path(dictionary, rqfile, prefix=[]):
    for filename in dictionary.keys():
        path = prefix + [filename]
        if not isinstance(dictionary[filename], dict):
            if rqfile in str(os.path.join(*path)):
                return str(os.path.join(*path))
        else:
            get_path(directory[filename], rqfile, path)
Salin selepas log masuk

Penyelesaian

Untuk menyelesaikan isu ini, fungsi perlu mengembalikan hasil panggilan rekursif. Secara lalai, fungsi Python mengembalikan Tiada jika tiada pernyataan pulangan yang jelas. Untuk mengembalikan laluan yang betul, gantikan baris terakhir fungsi dengan yang berikut:

return get_path(directory[filename], rqfile, path)
Salin selepas log masuk

Pengubahsuaian ini memastikan fungsi mengembalikan laluan yang ditemui semasa panggilan rekursif. Berikut ialah kod yang dikemas kini:

def get_path(dictionary, rqfile, prefix=[]):
    for filename in dictionary.keys():
        path = prefix + [filename]
        if not isinstance(dictionary[filename], dict):
            if rqfile in str(os.path.join(*path)):
                return str(os.path.join(*path))
        else:
            return get_path(directory[filename], rqfile, path)
Salin selepas log masuk

Atas ialah kandungan terperinci Mengapa Fungsi Python Rekursif Saya Tiada Kembali Apabila Mencari Fail dalam Kamus Bersarang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan