Python's Equivalent to PHP's natsort for Natural Order Sorting
Soalan yang sering ditanya dalam Python ialah cara mengisih senarai dalam susunan semula jadi, serupa kepada fungsi natsort PHP. Tidak seperti isihan standard, tertib semula jadi menganggap aksara angka sebagai nombor dan bukannya rentetan.
Sebagai contoh, pertimbangkan untuk mengisih senarai nama fail:
<code class="python">l = ['image1.jpg', 'image15.jpg', 'image12.jpg', 'image3.jpg'] l.sort()</code>
Isihan standard ini akan menghasilkan:
['image1.jpg', 'image12.jpg', 'image15.jpg', 'image3.jpg']
Walau bagaimanapun, untuk mencapai pengisihan tertib semula jadi, Python menyediakan fungsi utama yang menukar rentetan kepada tupel berangka jika boleh. Ini membolehkan perbandingan angka yang betul.
Berikut ialah contoh pelaksanaan:
<code class="python">import re def natsort_key(s): return map(int, re.findall(r'(\d+)', s))</code>
Menggunakan kunci ini semasa pengisihan menghasilkan susunan semula jadi yang diingini:
<code class="python">l.sort(key=natsort_key)</code>
Output akan menjadi:
['image1.jpg', 'image3.jpg', 'image12.jpg', 'image15.jpg']
Sebagai alternatif, jika anda memerlukan pengisihan tidak sensitif huruf besar-besaran, pelaksanaan yang lebih lengkap boleh digunakan:
<code class="python">def natcasecmp(a, b): return natcmp(a.lower(), b.lower())</code>
Ini menyediakan pengisihan susunan semula jadi yang tidak sensitif huruf.
Atas ialah kandungan terperinci Bagaimana untuk Mencapai Pengisihan Pesanan Semulajadi dalam Python Seperti natsort PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!