在Python中如何讓字典保持有序
1、如何讓字典保持有序
實際案例:
某編程競賽系統(tǒng),對參賽選手編程解題進行計時,選手完成題目后,把該選手解題用時記錄到字典中,以便賽后按選手名查詢成績。(答題用時越短,成績越優(yōu)秀。)
如:LiLei第2名用時43分鐘,HanMeimei第5名用時52分鐘,Jim第1名用時39分鐘
{'LiLei': (2, 43), 'HanMeimei': (5, 52), 'Jim': (1, 39), ...}
比賽結(jié)束后,需要按排名順序依次打印選手成績,如何實現(xiàn)?
注:為什么不用列表而用字典?就是為了方便賽后可以按名字查詢成績。
Python V3.6版本之前字典無序,3.6版本之后字典開始有序。
解決方案:
- 使用
collections.OrderedDict
(有序字典) - 以
OrderedDict
代替內(nèi)置字典Dict,依次將選手成績存入OrderDict
2、代碼演示
(1)OrderedDict有序字典簡單使用
d = dict() print(d) d['Jim'] = (1, 35) d['Leo'] = (2, 37) d['Bob'] = (3, 40) print(d) ? # 希望迭代字典時候,按每項先后進入順序打印 for k in d: ? ? print(k) ? # 導(dǎo)入有序字典 from collections import OrderedDict ? d2 = OrderedDict() d['Jim'] = (1, 35) d['Leo'] = (2, 37) d['Bob'] = (3, 40) for k in d: ? ? print(k)
(2)模擬編寫競賽答題
# 編程模擬選手 players = list('ABCDEF') # 模擬選手的答題時間 from time import time from random import randint from collections import OrderedDict ? d = OrderedDict() start = time() for i in range(6): ? ? # 等待用戶輸入,作為阻斷進程 ? ? input() ? ? # 每次隨機選擇一名選手答題完畢 ? ? p = players.pop(randint(0, 5 - i)) ? ? end = time() ? ? print(i + 1, p, end - start) ? ? # 記錄成績 ? ? d[p] = (i + 1, end - start) ? print() print('-' * 20) # 按先后進入字典順序,打印成績單 for k in d: ? ? print(k, d[k])
到此這篇關(guān)于在Python中如何讓字典保持有序的文章就介紹到這了,更多相關(guān)Python字典有序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python使用pymysql模塊操作mysql增刪改查實例分析
這篇文章主要介紹了Python使用pymsql模塊操作mysql增刪改查,結(jié)合實例形式分析了Python使用pymsql模塊針對mysql進行增刪改查操作的相關(guān)實現(xiàn)方法與操作注意事項,需要的朋友可以參考下2019-12-12python實現(xiàn)自動登錄后臺管理系統(tǒng)
這篇文章主要為大家詳細介紹了python實現(xiàn)自動登錄后臺管理系統(tǒng),并進行后續(xù)操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-10-10Pytorch實現(xiàn)的手寫數(shù)字mnist識別功能完整示例
這篇文章主要介紹了Pytorch實現(xiàn)的手寫數(shù)字mnist識別功能,結(jié)合完整實例形式分析了Pytorch模塊手寫字識別具體步驟與相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2019-12-12