Python3.7中的无序字典
本教程将介绍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
好了关于Python3.7中的无序字典的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。