Maison > Article > développement back-end > Comment trier des listes avec plusieurs clés, y compris l'ordre inversé en 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!