Python3字典排序


創建一個字典

dict1={'a':2,'b':3,'c':8,'d':4}

 

1、分別取鍵、值

取字典的所有鍵,所有的值,利用dict1.keys()dict1.vaules()

由於鍵,值有很多個,所以要加s,另外注意這里要加括號,這樣的小細節不注意,很容易犯錯。

print(dict1.values(),dict1.keys())

結果:

dict_values([4, 2, 8, 3]) dict_keys(['d', 'a', 'c', 'b'])

可以看出,返回的是列表的形式

 

2、同時取鍵、值

同時取字典的鍵、值,dict1.items(),這里同樣加s和括號

print(dict1.items())

結果:

dict_items([('d', 4), ('a', 2), ('c', 8), ('b', 3)])

可以看出,返回的結果是元組組成的列表

也就是說,通過dict1.items()這個函數,把字典形式的鍵、值,存在了一個元組內。

 

3、排序

3.1 sorted

先看一下,直接用sorted()排序的情況。

    dict1={'a':2,'e':3,'f':8,'d':4}

    dict2 = sorted(dict1)

    print(dict2)

結果:

['a', 'd', 'e', 'f']

sorted()默認是對字典的鍵,從小到大進行排序

 

3.2 、對鍵反向排序

對鍵進行反向(從大到小)排序

    dict1={'a':2,'e':3,'f':8,'d':4}

    dict2 = sorted(dict1,reverse=True)

    print(dict2)

    結果:['f', 'e', 'd', 'a']

像這種對鍵進行排序,往往是為了得到 值(value

拿到鍵最大,對應的值,如:

print(dict1[dict2[0]])#結果為8

當然我們也可以先拿到所有的key,然后再對key排序

    dict1={'a':2,'e':3,'f':8,'d':4}

    list1= sorted(dict1.keys(),reverse=True)

    print(list1)    # 結果:['f', 'e', 'd', 'a']

 

3.3、對值排序

同樣,用dict1.values()得到所有的values,然后對value排序

    dict1={'a':2,'e':3,'f':8,'d':4}

    list1= sorted(dict1.values())

    print(list1)    #結果:[2, 3, 4, 8]

設值reverse=True 進行反向排序

也可以用dict1.items(),得到包含鍵,值的元組

由於迭代對象是元組,返回值自然是元組組成的列表

這里對排序的規則進行了定義,x指元組,x[1]是值,x[0]是鍵

    dict1={'a':2,'e':3,'f':8,'d':4}

    list1= sorted(dict1.items(),key=lambda x:x[1])

    print(list1)

結果:

[('a', 2), ('e', 3), ('d', 4), ('f', 8)]

對鍵進行排序:

    dict1={'a':2,'e':3,'f':8,'d':4}

    list1= sorted(dict1.items(),key=lambda x:x[0])

    print(list1)

結果:

[('a', 2), ('d', 4), ('e', 3), ('f', 8)]

 

4 itemgetter

    from operator import itemgetter

    d = {"a":8,"b":4,"c":12}

    print(sorted(d.items(),key=itemgetter(0),reverse=True))

    print(sorted(d.items(),key=itemgetter(1),reverse=True))

結果:

    [('c', 12), ('b', 4), ('a', 8)]

    [('c', 12), ('a', 8), ('b', 4)]

itemgetter(0),獲取key

itemgetter(1),獲取value

---------------------

 

轉自原文:https://blog.csdn.net/ustbbsy/article/details/79637594


免責聲明!

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



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