1. 程式人生 > >Python sort方法

Python sort方法

def .so lar div des method functions ans too

官方文檔:

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]
>>> 

Python sort方法