Inverse Dictionary Lookup in Python: An Efficient Approach
Semasa melelaran melalui kamus untuk mencari kunci yang sepadan dengan nilai yang diberikan boleh menyusahkan , wujud penyelesaian mudah menggunakan ungkapan penjana.
Untuk menggambarkan, mari kita pertimbangkan kamus bernama 'dd.' Pendekatan tradisional, seperti yang anda cadangkan, melibatkan pemahaman senarai:
<code class="python">key = [key for key, value in dd.items() if value == 'value'][0]</code>
Kaedah ini melibatkan lelaran melalui keseluruhan item kamus, menggunakan sumber walaupun selepas mencari padanan pertama.
Untuk mengoptimumkan proses, kita boleh menggunakan ungkapan penjana:
<code class="python">key = next(key for key, value in dd.items() if value == 'value')</code>
Ungkapan ini menggunakan fungsi 'seterusnya', yang mengambil penjana sebagai hujahnya. Penjana bergerak melalui item kamus sehingga ia menemui padanan, menghasilkan kunci yang sepadan.
Dengan menggunakan ungkapan penjana, kami meminimumkan lelaran yang tidak perlu, meningkatkan kecekapan proses carian kamus songsang dengan ketara. Perlu diingat bahawa jika tiada padanan ditemui, ungkapan penjana akan menimbulkan pengecualian 'StopIteration'.
Atas ialah kandungan terperinci Bagaimana untuk Melakukan Carian Kamus Songsang yang Cekap dalam Python Menggunakan Ungkapan Penjana?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!