有序字典-OrderedDict簡介
示例
有序字典和通常字典類似,只是它可以記錄元素插入其中的順序,而一般字典是會以任意的順序迭代的。參見下面的例子:
import collectionsprint 'Regular dictionary:'d = {}d['a'] = 'A'd['b'] = 'B'd['c'] = 'C'd['d'] = 'D'd['e'] = 'E'for k, v in d.items(): print k, vprint '/nOrderedDict:'d = collections.OrderedDict()d['a'] = 'A'd['b'] = 'B'd['c'] = 'C'd['d'] = 'D'd['e'] = 'E'for k, v in d.items(): print k, v
運行結果如下:
-> python test7.pyRegular dictionary:a Ac Cb Be Ed DOrderedDict:a Ab Bc Cd De E
可以看到通常字典不是以插入順序遍歷的。
相等性
判斷兩個有序字段是否相等(==)需要考慮元素插入的順序是否相等
import collectionsprint 'dict :',d1 = {}d1['a'] = 'A'd1['b'] = 'B'd1['c'] = 'C'd1['d'] = 'D'd1['e'] = 'E'd2 = {}d2['e'] = 'E'd2['d'] = 'D'd2['c'] = 'C'd2['b'] = 'B'd2['a'] = 'A'print d1 == d2print 'OrderedDict:',d1 = collections.OrderedDict()d1['a'] = 'A'd1['b'] = 'B'd1['c'] = 'C'd1['d'] = 'D'd1['e'] = 'E'd2 = collections.OrderedDict()d2['e'] = 'E'd2['d'] = 'D'd2['c'] = 'C'd2['b'] = 'B'd2['a'] = 'A'print d1 == d2
運行結果如下:
-> python test7.pydict : TrueOrderedDict: False
而當判斷一個有序字典和其它普通字典是否相等只需判斷內容是否相等。
注意
OrderedDict 的構造器或者 update() 方法雖然接受關鍵字參數,但因為python的函數調用會使用無序的字典來傳遞參數,所以關鍵字參數的順序會丟失,所以創造出來的有序字典不能保證其順序。
參考資料
https://docs.python.org/2/library/collections.html#collections.OrderedDict
https://pymotw.com/2/collections/ordereddict.html
新聞熱點
疑難解答