分享

Python字典到底有序还是无序?

 编程教室 2024-05-13 发布于江苏

Python中的字典dict,到底是无序的还是有序的?

有人说无序;也有人说以前无序,但3.6开始改成有序了。

两种说法都对,但这个有序无序,可能跟你想的不太一样。

老版本Python中的dict确实无序,你写的是a、b、c,输出却可能是c、b、a。

而从Python3.6开始,dict的插入顺序是保持的。key的顺序跟你定义时的先后顺序一致,重复的键和修改已有键值不改变顺序。

这样的好处是让程序的行为更加可预测,比如从一个JSON格式的字符串中读取了数据,修改了其中项,再重新保存,就不会打乱原有的数据结构。

import jsonconfig = '{\"hostname":"python666.cn", \"port": 8080, \"debug": true, \"timeout": 60\}'print(config)config_dict = json.loads(config)config_dict['port'] = 8888config_dict['debug'] = Falseconfig = json.dumps(config_dict)print(config)

而在3.6之前版本,实现同样的效果就要用到 collections 模块的 OrderedDict 类型,它是 dict 的一个子类,但增加了对插入顺序的保持

但即便如此,你说现在的Python字典是无序的也有一定道理。

比较两个元素相同但顺序不同的字典是否相等,结果是True。这是因为dict定义的相等性比较是基于元素的内容,而不考虑插入的顺序。

相比之下,刚刚提到的OrderedDict,才真的是名副其实的有序。比较相等时不但要元素相同,顺序也要一致。

所以你觉得,python字典到底应该称为有序还是无序呢?

作者:Crossin的编程教室

    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多