官方文档:
sort
(*, key=None, reverse=False)
This method sorts the list in place, using only <
comparisons between items. Exceptions are not suppressed - if any comparison operations fail, the entire sort operation will fail (and the list will likely be left in a partially modified state).
sort()
accepts two arguments that can only be passed by keyword (keyword-only arguments):
key specifies a function of one argument that is used to extract a comparison key from each list element (for example, key=str.lower
). The key corresponding to each item in the list is calculated once and then used for the entire sorting process. The default value of None
means that list items are sorted directly without calculating a separate key value.
The functools.cmp_to_key()
utility is available to convert a 2.x style cmp function to a key function.
reverse is a boolean value. If set to True
, then the list elements are sorted as if each comparison were reversed.
This method modifies the sequence in place for economy of space when sorting a large sequence. To remind users that it operates by side effect, it does not return the sorted sequence (use sorted()
to explicitly request a new sorted list instance).
The sort()
method is guaranteed to be stable. A sort is stable if it guarantees not to change the relative order of elements that compare equal — this is helpful for sorting in multiple passes (for example, sort by department, then by salary grade).
CPython implementation detail: While a list is being sorted, the effect of attempting to mutate, or even inspect, the list is undefined. The C implementation of Python makes the list appear empty for the duration, and raises ValueError
if it can detect that the list has been mutated during a sort.
sort()只能对纯数字或字母进行排序, 否则报错:
>>> alist [1, 3, 4, 7, 8, 9] >>> alist.append('a') >>> alist.sort() Traceback (most recent call last): File "<pyshell#83>", line 1, in <module> alist.sort() TypeError: '<' not supported between instances of 'str' and 'int' >>>
sort()可以不带参数或最多带两个关键字参数,默认key=None, reverse=False, 默认升序排列:
>>> alist = [1,4,2,7,9,3] >>> alist.sort() >>> alist [1, 2, 3, 4, 7, 9] >>>
指定reverse=True时降序排列:
>>> alist = [1,4,2,7,9,3] >>> alist.sort(reverse=True) >>> alist [9, 7, 4, 3, 2, 1] >>>
如果想保持原list不变,拷贝一个新list出来排序:
>>> alist = [1,4,2,7,9,3] >>> blist = alist[:] #不能写blist = alist,这样写是让blist指向alist同一内存空间 >>> blist.sort() >>> alist [1, 4, 2, 7, 9, 3] >>> blist [1, 2, 3, 4, 7, 9] >>>
或者用sorted()方法:
>>> alist = [1,4,2,7,9,3] >>> blist = sorted(alist) >>> alist [1, 4, 2, 7, 9, 3] >>> blist [1, 2, 3, 4, 7, 9] >>>