Python3.7中的无序字典

本教程将介绍Python3.7中的无序字典的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

Python3.7中的无序字典 教程 第1张

问题描述

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