Python3.7中的无序字典
问题描述
从Python3.6开始订购Python中的词典
发件人-https://stackoverflow.com/a/39980744/4647107
词典是否在Python3.6+中订购?
它们按插入顺序排列。从Python3.6开始,用于CPython. 实现了Python,词典记住了条目的顺序 已插入。这被认为是Python3.6中的一个实现细节; 如果您想要插入顺序,则需要使用OrderedDict 保证在其他Python实现中使用。
从Python3.7开始,这不再是一个实现细节 相反,它变成了一种语言功能。来自gvr的python-dev消息:就这么办吧。"DICT保持插入顺序"是裁决。谢谢!
这仅仅意味着您可以依赖它。的其他实现 如果希望,Python还必须提供插入排序词典 成为符合Python3.7标准的实现。
现在有没有办法在Python中实现无序字典?
解决方案
正如一些人提到的,这将有助于理解为什么您想要一个无序的词典。就我个人而言,我在寻找无序的Dicts,因为我正在使用OrderedDicts,而它们的行为意味着我不能使用==
直接比较它们。例如:
In [1]: from collections import OrderedDict
In [2]: dict_1 = OrderedDict([('a', 0), ('b', 1), ('c', 2)])
In [3]: dict_2 = OrderedDict([('c', 2), ('b', 1), ('a', 0)])
In [4]: dict_1 == dict_2
Out[4]: False
解决此问题的一个简单方法是将OrderedDict重新转换为字典。
In [5]: dict(dict_1) == dict(dict_2)
Out[5]: True
相关文章