本文實例講述了Python讓字典保持有序的方法。分享給大家供大家參考,具體如下:
問題:創(chuàng)建一個字典,同時對字典做迭代或序列化操作時,也能控制其中元素的順序;
解決方案:可以使用collections模塊中的OrderedDict類來控制字典中元素的順序。當(dāng)對字典做迭代時,他會嚴格按照元素初始添加的順序進行。例如:
from collections import OrderedDictd=OrderedDict()d['foo']=1d['bar']=2d['spam']=3d['grok']=4for key in d: print(key,d[key])
Python 3.4.0 (v3.4.0:04f714765c13, Mar 16 2014, 19:24:06) [MSC v.1600 32 bit (Intel)] on win32Type "copyright", "credits" or "license()" for more information.>>> ================================ RESTART ================================>>> foo 1bar 2spam 3grok 4>>>
當(dāng)想構(gòu)建一個映射結(jié)構(gòu)以便稍后對其做序列化或編碼成另一種格式時,OrderedDict就顯得特別有用。
例如:若想在進行JSON編碼時精確控制各字段的順序,那么只要首先在OrderedDict中構(gòu)建數(shù)據(jù)就可以了。
>>> import json>>> dOrderedDict([('foo', 1), ('bar', 2), ('spam', 3), ('grok', 4)])>>> json.dumps(d)'{"foo": 1, "bar": 2, "spam": 3, "grok": 4}'>>>補充:OrderedDict內(nèi)部維護了一個雙向鏈表,它會根據(jù)元素加入的順序排列鍵的位置。第一個新加入的元素被放置在鏈表的末尾,接下來對已存在的鍵做重新賦值不會改變鍵的順序。
注意:OrderedDict的大小是普通字典的2倍,這是它額外創(chuàng)建的鏈表所致。所以在構(gòu)建涉及大量數(shù)據(jù)的結(jié)構(gòu)時要權(quán)衡其帶來的好處與消耗的內(nèi)存。
(代碼摘自《Python Cookbook》)
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
新聞熱點
疑難解答
圖片精選