1.7字典排序

问题

​ 你想创建一个字典,并且在迭代或序列化这个字典的时候能够控制元素的顺序。

解决方案

​ 为了能控制一个字典中元素的顺序,你可以使用collection模块中的OrderedDict类。在迭代操作的时候它会保持元素被插入时的顺序,示例如下:

from collections import OrderedDict
d=OrderedDict()
d['foo']=1
d['bar']=2
d['spam']=3
d['grok']=4
for key in d:
    print(key,d[key])
    '''
foo 1
bar 2
spam 3
grok 4
    '''

​ 当你想要构建又给将需要序列化或编码成其他格式的映射的时候,OrderedDict是非常有用的。比如,你想精确控制以json编码后字段的顺序,你可以先使用OrderedDict来构建这样的数据:

import json
print(json.dumps(d))  # -》{"foo": 1, "bar": 2, "spam": 3, "grok": 4}

讨论

​ OrderedDict内部维护着一个根据键插入顺序排序的双表链表。每次当一个新的元素插入进来的时候,它会被放到链表的尾部。对于一个已经存在的键的重复赋值不会改变键的顺序。

​ 需要注意的是,一个OrderedDict内部维护着又给根据键插入顺序排序的双向列表链表。所以如果你要构建一个需要大量OrderedDict实例数据结构的时候,那么你就得仔细权衡一下是否使用OrderedDict带来好处要大过额外内存消耗的影响

posted @   qiupeng  阅读(39)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示