Maison  >  Article  >  développement back-end  >  Comment trier des listes avec plusieurs clés, y compris l'ordre inversé en Python ?

Comment trier des listes avec plusieurs clés, y compris l'ordre inversé en Python ?

Susan Sarandon
Susan Sarandonoriginal
2024-11-02 05:58:03723parcourir

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

Tri des listes avec plusieurs clés, y compris l'ordre inversé

Python fournit la fonction sorted() pour trier les listes. Pour trier selon plusieurs clés, une fonction lambda peut être utilisée comme argument clé. Cependant, lors d'un tri avec plusieurs clés, toutes les clés sont triées par défaut par ordre croissant.

Considérons une liste de tuples :

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

Pour trier cette liste à l'aide des deux clés, le code suivant peut être utilisé :

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

Ce code trie les éléments par ordre croissant par la première clé puis par la deuxième clé dans l'ordre croissant. Pour trier dans l'ordre inverse avec une clé, la fonction lambda peut être modifiée :

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

Dans cet exemple, le signe négatif avant y[1] inverse l'ordre de tri pour la deuxième clé. Cependant, ce code triera tous les éléments dans l'ordre inverse par la deuxième clé.

Pour trier dans l'ordre inverse par une clé et par ordre croissant par l'autre, le code suivant peut être utilisé :

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

Ici, le signe négatif est utilisé avec la première clé pour inverser l'ordre de tri de la première clé.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn