案例: 對以字典形式存儲的成績按成績高低進行排序,計算學生排名。
{'a':90,'b':91,'c':89}
解決方案:使用內置函數 sorted() - 使用C語言速度
1.使用zip()函數 將字典轉換成元祖
2.使用sorted() 的 參數辦法進行排序
Out[1]: from random import randint
Out[2]: {x : randint(60,100) for x in 'xyzabc'}
Out[2]: {'a': 75, 'b': 71, 'c': 67, 'x': 60, 'y': 64, 'z': 72}
sorted(d) #直接對鍵排序,無法達到預期效果
In [5]: sorted(d)
Out[5]: ['a', 'b', 'c', 'x', 'y', 'z']
#進行鍵值轉換 - 轉換成元組
In [6]: d.keys()
Out[6]: dict_keys(['a', 'z', 'y', 'c', 'x', 'b'])
In [7]: d.values()
Out[7]: dict_values([89, 77, 86, 60, 67, 86])
#使用zip() 將字典數據轉化為元祖
In [8]: zip(d.values(),d.keys())
Out[8]: <zip at 0x2719e17fc08>
In [17]: c=zip(d.values(),d.keys())
In [19]: sorted(c)
Out[19]: [(60, 'c'), (67, 'x'), (77, 'z'), (86, 'b'), (86, 'y'), (89, 'a')]
#傳遞sorted 函數的key參數
In [20]: d.items()
Out[20]: dict_items([('a', 89), ('z', 77), ('y', 86), ('c', 60), ('x', 67), ('b', 86)])
In [21]: sorted(d.items(),key = lambda x:x[1])
Out[21]: [('c', 60), ('x', 67), ('z', 77), ('y', 86), ('b', 86), ('a', 89)]
d.keys()