python3中的sorted()函式
阿新 • • 發佈:2018-11-09
請先看下面一個例題:
對字串排序時,有時候忽略大小寫排序更符合習慣。請利用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,後面的比較函式沒法作用到前面的的元素。