字典排序


使用sorted對字典進行排序。

描述

sorted() 函數對所有可迭代的對象進行排序操作。

sort 與 sorted 區別:

sort 是應用在 list 上的方法,sorted 可以對所有可迭代的對象進行排序操作。

list 的 sort 方法返回的是對已經存在的列表進行操作,而內建函數 sorted 方法返回的是一個新的 list,而不是在原來的基礎上進行的操作。

 

語法

sorted 語法:

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

參數說明:

  • iterable -- 可迭代對象。
  • key -- 主要是用來進行比較的元素,只有一個參數,具體的函數的參數就是取自於可迭代對象中,指定可迭代對象中的一個元素來進行排序。
  • reverse -- 排序規則,reverse = True 降序 , reverse = False 升序(默認)。

返回值

返回重新排序的列表。

 

實例

1.對key值排序

#默認key
>>> d
{'a': 2, 'e': 5, 'c': 1} >>> sorted(d) ['a', 'c', 'e']
反向 >>> sorted(d,reverse=True) ['e', 'c', 'a']
#使用d.keys()
>>> sorted(d.keys())
['a', 'c', 'e'] #反向 >>> sorted(d.keys(),reverse=True) ['e', 'c', 'a']

 

2.對value進行排序

>>> d
{'a': 2, 'e': 5, 'c': 1}
>>> sorted(d.values())
[1, 2, 5]
反向
>>> sorted(d.values(),reverse=True)
[5, 2, 1]

 

3.分別根據key和value排序,保留key和value值

>>> d
{'a': 2, 'e': 5, 'c': 1}
#對鍵進行排序
>>> sorted(d.items())
[('a', 2), ('c', 1), ('e', 5)]
>>> sorted(d.items(),reverse=True)
[('e', 5), ('c', 1), ('a', 2)]

>>> sorted(d.items(),key=lambda x:x[0])
[('a', 2), ('c', 1), ('e', 5)]
>>> sorted(d.items(),key=lambda x:x[0],reverse=True)
[('e', 5), ('c', 1), ('a', 2)]

#對值進行排序
>>> sorted(d.items(),key=lambda x:x[1])
[('c', 1), ('a', 2), ('e', 5)]
>>> sorted(d.items(),key=lambda x:x[1],reverse=True)
[('e', 5), ('a', 2), ('c', 1)]

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM