Le contenu de Trier COMMENT FAIRE - Document Python 3.5.1 et des conseils supplémentaires.
list.sort()
>>> a = [3, 0, 5, 1]
>>> a.sort()
>>> a
[0, 1, 3, 5]
>>> print(a.sort()) #Il n'y a pas de valeur de retour
None
sorted(list)
--Retourne le résultat du tri de la liste.
>>> a = [3, 0, 5, 1]
>>> sorted(a)
[0, 1, 3, 5]
>>> a #La liste d'origine reste inchangée
[3, 0, 5, 1]
>>> sorted(iter([3, 0, 5, 1])) #Peut être utilisé pour d'autres que des listes
[0, 1, 3, 5]
reverse = True
.>>> a = [3, 0, 5, 1]
>>> sorted(a, reverse=True)
[5, 3, 1, 0]
--Spécifiez une fonction ou une expression lambda dans key
.
>>> a = ["c", "aaa", "Bb"]
>>> sorted(a, key=lambda x: x.lower())
['aaa', 'Bb', 'c']
>>> sorted(a, key=str.lower)
['aaa', 'Bb', 'c']
>>> sorted(a, key=len)
['c', 'Bb', 'aaa']
--Par défaut, les éléments sont comparés dans l'ordre.
python
>>> a = [("b", 3), ("b", 1), ("a", 1), ("a", 2), ("c", 2)]
>>> sorted(a)
[('a', 1), ('a', 2), ('b', 1), ('b', 3), ('c', 2)]
python
>>> a = [{"key1": 3}, {"key1": 1}]
>>> from operator import itemgetter
>>> sorted(a, key=itemgetter("key1"))
[{'key1': 1}, {'key1': 3}]
python
>>> from datetime import date
>>> a = [date(2016, 1, 1), date(2015, 12, 1)]
>>> from operator import attrgetter
>>> sorted(a, key=attrgetter("month"))
[datetime.date(2016, 1, 1), datetime.date(2015, 12, 1)]
python
>>> a = [("b", 3), ("b", 1), ("a", 1), ("a", 2), ("c", 2)]
>>> b = sorted(a, key=itemgetter(1), reverse=True)
>>> sorted(b, key=itemgetter(0))
[('a', 2), ('a', 1), ('b', 3), ('b', 1), ('c', 2)]
--Itemgetter et attrgetter peuvent spécifier plusieurs clés à la fois, utilisez donc ceci si les ordres décroissant et croissant sont les mêmes pour toutes les clés.
python
>>> sorted(a, key=itemgetter(0, 1))
[('a', 1), ('a', 2), ('b', 1), ('b', 3), ('c', 2)]
>>> a = [3, 0, None, 5, 1]
>>> sorted(a) #Le tri échoue normalement
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unorderable types: NoneType() < int()
>>> sorted(a, key=lambda x: (x is None, x)) #Aucun à la fin
[0, 1, 3, 5, None]
>>> sorted(a, key=lambda x: (x is not None, x)) #Aucun au début
[None, 0, 1, 3, 5]
Python sort list with None at the end - Stack Overflow
__lt__ ()
.class P(object):
def __init__(self, gender, age):
self.gender = gender
self.age = age
def __repr__(self):
return "{:s}{:d}".format(self.gender, self.age)
def __lt__(self, other):
return (self.gender, self.age) < (other.gender, other.age)
a = [P("F", 30), P("F", 20), P("M", 20), P("M", 40), P("F", 10)]
print(sorted(a))
-Utiliser heapq.merge.
>>> import heapq
>>> list(heapq.merge([1, 3, 4, 7], [2, 5], [6]))
[1, 2, 3, 4, 5, 6, 7]
Recommended Posts