Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Mencari Kejadian Nth Substring dalam Python dengan Cekap?
Mencari Kejadian Nth Subrentetan dalam Python
Mengenal pasti kedudukan kejadian subrentetan tertentu dalam rentetan yang lebih besar ialah tugas pengaturcaraan yang kerap . Bagi pembangun Python pemula, mencapai ini dengan cekap dan idiomatik boleh menimbulkan cabaran. Artikel ini bertujuan untuk menjelaskan pelbagai kaedah yang tersedia untuk mencari kejadian ke-n bagi subrentetan, memfokuskan pada pendekatan yang paling Pythonic.
Pendekatan Berulang
Penyelesaian berulang yang mudah melibatkan mencari subrentetan beberapa kali. Secara lalai, kaedah find() Python mencari kejadian pertama sahaja. Untuk mendapatkan kejadian ke-n, kita boleh mencari secara berturut-turut bermula dari kedudukan sejurus selepas kejadian sebelumnya:
<code class="python">def find_nth(haystack: str, needle: str, n: int) -> int: start = haystack.find(needle) while start >= 0 and n > 1: start = haystack.find(needle, start+len(needle)) n -= 1 return start</code>
Kaedah ini adalah mudah dan cekap ingatan.
Kejadian Bertindih
Jika kejadian pertindihan ke-n dikehendaki, kenaikan dalam kaedah find() hendaklah dilaraskan:
<code class="python">def find_nth_overlapping(haystack, needle, n): start = haystack.find(needle) while start >= 0 and n > 1: start = haystack.find(needle, start+1) n -= 1 return start</code>
Pertimbangan Python
Berbanding dengan penyelesaian menggunakan ungkapan biasa atau pemisahan rentetan, pendekatan berulang mematuhi prinsip reka bentuk Python iaitu kesederhanaan, kerataan dan kebolehbacaan:
Atas ialah kandungan terperinci Bagaimana untuk Mencari Kejadian Nth Substring dalam Python dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!