字典的無序是指資料存進字典的順序跟取出字典的順序不一致
Python2的字典是無序的
>>> d = {'a':-1,'b':-1,'c':-1}>>> d {'a': -1, 'c': -1, 'b': -1}>>> for k,v in d.items(): ... print k,v ... a -1c -1b -1
那要如何保持字典有序呢?使用OrderedDict
>>> from collections import OrderedDict >>> d = OrderedDict() >>> d['a'] = 1 >>> d['b'] = 2 >>> d['c'] = 3 >>> d OrderedDict([('a', 1), ('b', 2), ('c', 3)]) >>> for k,v in d.items(): ... print k,v ... a 1 b 2 c 3
那為什麼會是無序的呢?哈希結構會有一個head位址,裡面的資料會分散到不同的列表鏈,所以看似是無序的,但對於同一組字典,總需要有一個標識去連結,所以讀取時也會按存儲順序取數據,但不會依特定規則排列。
Python3中字典是有順序的
>>> d = {'a':-1,'b':-1,'c':-1} >>> d {'a': -1, 'b': -1, 'c': -1} >>> for k,v in d.items(): ... print(k,v) ... a -1 b -1 c -1
以上是python中字典是有序的嗎的詳細內容。更多資訊請關注PHP中文網其他相關文章!