最好是采用 OrderedDict + json.dumps方案
1. 在存儲 content 的時候就使用 OrderedDict 而非用默認的 dict
from collections import OrderedDict content = OrderedDict(); content['id'] = "evt_ugB6x3K43D16wXCcqbplWAJo" ..... content['created'] = 1440407501 jcont = json.dump(content); # {"id":"evt_ugB6x3K43D16wXCcqbplWAJo","created":1440407501} # type(jcont) #<type 'str'>
這樣得出的最終的 dict 從頭到尾都是有序的, OrderedDict 其實可以看做是 dict 的一個子類,強行保留了其字典序,但是這樣消耗的資源要更多。
2. 如果要重新轉化為 json 格式但是仍要保證其已有順序需要在 json.loads() 中使用參數 object_pairs_hook
jod = json.loads(jcont, object_pairs_hook=OrderedDict); type(jod) # <type collections.OrderedDict>
這樣才是一個完整的保證出入有序的方案。