1. 程式人生 > >python3中的sorted()函式

python3中的sorted()函式

請先看下面一個例題:
對字串排序時,有時候忽略大小寫排序更符合習慣。請利用sorted()高階函式,實現忽略大小寫排序的演算法。
輸入:['bob', 'about', 'Zoo', 'Credit']
輸出:['about', 'bob', 'Credit', 'Zoo']
def cmp_ignore_case(x):
    return x.upper()

print ( sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case) );

執行結果:

Traceback (most recent call last):
  File "D:/python/TestPython/venv/advanced/FunctionFormula.py", line 59, in <module>
    print ( sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case) );
TypeError: sorted expected 1 arguments, got 2

當修改為下面兩種結果是就沒問題:

def cmp_ignore_case(x):
    return x.upper()
print ( sorted(['bob', 'about', 'Zoo', 'Credit'], key = cmp_ignore_case) );
>>> ['about', 'bob', 'Credit', 'Zoo']

print ( sorted(['bob', 'about', 'Zoo', 'Credit'], key = lambda x: x.upper()) );
>>> ['about', 'bob', 'Credit', 'Zoo']

原因是:

這個是python2和python3的區別,

python3 sorted取消了對cmp的支援。

sorted(iterable, key=None, reverse=False)

  • reverse是一個布林值。如果設定為True,列表元素將被倒序排列,預設為False

  • key接受一個函式,這個函式只接受一個元素,預設為None

sorted([36, 5, 12, 9, 21], reverse=True)就可以實現倒序

Python2中的自定義布林函式cmp=custom_cmp(x, y)由Python3中的key=custom_key(x)代替,2中是返回-1,1,0

在python3中,待比較元素x通過custom_key函式轉化為Python能比較的值custom_key(x),進而再基於返回值進行排序。3中是返回待比較的元素!

你可以想象成集合,集合就是需要用key來索引,因為它是無序的。沒有key,後面的比較函式沒法作用到前面的的元素。