Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Mencapai Pengisihan Pesanan Semulajadi dalam Python Seperti natsort PHP?

Bagaimana untuk Mencapai Pengisihan Pesanan Semulajadi dalam Python Seperti natsort PHP?

Patricia Arquette
Patricia Arquetteasal
2024-11-05 14:57:02882semak imbas

How to Achieve Natural Order Sorting in Python Like PHP's natsort?

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!

Kenyataan:
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