Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana Mengisih Senarai Dengan Berbilang Kekunci, Termasuk Susunan Terbalik dalam Python?

Bagaimana Mengisih Senarai Dengan Berbilang Kekunci, Termasuk Susunan Terbalik dalam Python?

Susan Sarandon
Susan Sarandonasal
2024-11-02 05:58:03723semak imbas

How to Sort Lists With Multiple Keys, Including Reverse Ordering in Python?

Isih Senarai dengan Berbilang Kekunci, Termasuk Susunan Terbalik

Python menyediakan fungsi sorted() untuk menyusun senarai. Untuk mengisih mengikut berbilang kunci, fungsi lambda boleh digunakan sebagai hujah utama. Walau bagaimanapun, apabila mengisih dengan berbilang kekunci, semua kekunci diisih mengikut tertib menaik secara lalai.

Pertimbangkan senarai tupel:

<code class="python">myList = [(ele1A, ele2A), (ele1B, ele2B), (ele1C, ele2C)]</code>

Untuk mengisih senarai ini menggunakan kedua-dua kekunci, kod berikut boleh digunakan:

<code class="python">sortedList = sorted(myList, key=lambda y: (y[0].lower(), y[1]))</code>

Kod ini mengisih elemen dalam tertib menaik mengikut kekunci pertama dan kemudian dengan kekunci kedua dalam tertib menaik. Untuk mengisih dalam susunan terbalik dengan satu kekunci, fungsi lambda boleh diubah suai:

<code class="python">sortedList = sorted(myList, key=lambda y: (y[0].lower(), -y[1]))</code>

Dalam contoh ini, tanda negatif sebelum y[1] membalikkan tertib isihan untuk kunci kedua. Walau bagaimanapun, kod ini akan mengisih semua elemen dalam susunan terbalik mengikut kekunci kedua.

Untuk mengisih dalam tertib songsang dengan satu kunci dan tertib menaik dengan yang lain, kod berikut boleh digunakan:

<code class="python">sortedList = sorted(myList, key=lambda y: (-y[0].lower(), y[1]))</code>

Di sini, tanda negatif digunakan dengan kekunci pertama untuk membalikkan tertib pengisihan bagi kunci pertama.

Atas ialah kandungan terperinci Bagaimana Mengisih Senarai Dengan Berbilang Kekunci, Termasuk Susunan Terbalik dalam Python?. 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