python_sorted()详解
生活随笔
收集整理的這篇文章主要介紹了
python_sorted()详解
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
文章目錄
- 1. sorted()介紹
- 2. 實際使用例子
- 2.1 字典排序: 按照字典的value值進行排序(從大到小)
- 2.2 字典排序: 按照字典的key值進行排序(從小到大)
- 2.3 對列表中的字典進行排序
- 3. 面試題
- 3.1 給定一個任意長度數(shù)組,實現(xiàn)一個函數(shù)
1. sorted()介紹
與map,filter,reduce一樣,sorted也是一個高階函數(shù)
語法:
sorted(iterable[, key[, reverse]])
參數(shù)說明:
- iterable – 可迭代對象(列表,字典,字符串等)
- key – 接受一個函數(shù)來實現(xiàn)自定義的排序(key指定的函數(shù)將作用于list的每一個元素上,并根據(jù)key函數(shù)返回的結果進行排序).
- reverse – 排序規(guī)則,reverse = False 升序(默認), reverse = True 降序
針對參數(shù)key進行補充:
可以自定義一個函數(shù),將可迭代對象中的每個元素依次放入函數(shù),例如元素A經(jīng)過函數(shù)后得到一個新的結果元素B(關于如何轉換就可以根據(jù)我們需要自定義),按照新的結果B進行排序,但是展示,還是按照該結果對應的元素A進行展示.
對比原始的list和經(jīng)過key=abs處理過的list:
list = [3, 2, -4, -10, 5] keys = [3, 2, 4, 10, 5]按照keys進行排序后, 將其對應的原始數(shù)據(jù)展示出來
用sorted()排序的關鍵在于實現(xiàn)一個映射函數(shù)。
2. 實際使用例子
2.1 字典排序: 按照字典的value值進行排序(從大到小)
dic = {'a':31, 'bc':5, 'c':3, 'asd':4, 'aa':74, 'd':0} dict= dict(sorted(dic.items(), key=lambda d:d[1], reverse = True)) print(dict) # {'aa': 74, 'a': 31, 'bc': 5, 'asd': 4, 'c': 3, 'd': 0}2.2 字典排序: 按照字典的key值進行排序(從小到大)
dic = {'a':31, 'bc':5, 'c':3, 'asd':4, 'aa':74, 'd':0} dict= dict(sorted(dic.items(), key=lambda d:d[0])) print(dict) # {'a': 31, 'aa': 74, 'asd': 4, 'bc': 5, 'c': 3, 'd': 0}2.3 對列表中的字典進行排序
- 直接根據(jù)字典中的value排序a = [{'a': 1, 'g': 19}, {'a': 2, 'g': 19}, {'a': 1, 'g': 11}] b = sorted(a, key=lambda x: x['a']) print(b) # 也可以這樣寫,python中一切皆對象 alist_sort = sorted(alist,key=lambda e: e.__getitem__('a'),reverse=True)
- 當字典元素中value數(shù)值相同的情況下,根據(jù)第二個value進行排序# 先根據(jù)a的值進行排序,如果a的值相同,就根據(jù)'g'的值進行排序 a = [{'a': 1, 'g': 19}, {'a': 2, 'g': 19}, {'a': 1, 'g': 11}] b = sorted(a, key=lambda x: (x['a'], x['g'])) # 外層還可以用 reverse = True 表示倒敘 print(b)
3. 面試題
3.1 給定一個任意長度數(shù)組,實現(xiàn)一個函數(shù)
讓所有奇數(shù)都在偶數(shù)前面,而且奇數(shù)升序排列,偶數(shù)降序排序,如字符串’1982376455’,變成’1355798642’
# 方法一 def func1(l):if isinstance(l, str):l = [int(i) for i in l]l.sort(reverse=True)for i in range(len(l)):if l[i] % 2 > 0:l.insert(0, l.pop(i))print(''.join(str(e) for e in l))# 方法二 def func2(l):print("".join(sorted(l, key=lambda x: int(x) % 2 == 0 and 20 - int(x) or int(x))))重點說一下方法二. python的編程宗旨就是簡潔
- "".join()# "".join() 將一個列表按照前方元素拼接為一個字符串 >>> ''.join(['a', 'b', 'c']) 'abc'
- sorted中的keysorted(l, key=lambda x: int(x) % 2 == 0 and 20 - int(x) or int(x))int(x) % 2 == 0 and 20 - int(x) or int(x) # 先判斷and部分: int(x) % 2 是否為偶數(shù),如果為偶數(shù)則返回 20 - int(x). 如果為奇數(shù)返回False # 然后判斷or部分: 如果前方表達式為False(即:為奇數(shù)),返回結果 int(x), 如果前方表達式不為False,返回該數(shù)值(即:20-int(x)) # 這里為什么用20,只是為了區(qū)分開了奇數(shù)和偶數(shù),單個數(shù)最大為8(針對偶數(shù)),20-8=12也比單個數(shù)大, 所以,你可以設置該數(shù)值為比8+9=17(包含17)大的任何數(shù)字,都可以. 這里說明的是,后面的邏輯運算符的運算. 請參考我的另一個文章: python中的邏輯運算符
總結
以上是生活随笔為你收集整理的python_sorted()详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python处理图片隐写分析_Pytho
- 下一篇: python画正方体_python绘制立