for循环将字典添加到列表中出现覆盖前面数据的问题
2024-10-15 13:49:29
出现问题:
rets = [{'id':1},{"id":2},{"id":3}] context = {}
context['count'] = len(rets)
req = []
res = {} for ret in rets:
res['a'] = ret['id']
req.append(res)
context['b'] = req
print(context)
如上述代码,想将rets中的数据通过for循环的方式添加到context里面想要得到如下类型的字典:
{'count': 3, 'b': [{'a': 1}, {'a': 2}, {'a': 3}]}
运行结果却是:
{'count': 3, 'b': [{'a': 3}, {'a': 3}, {'a': 3}]}
分析原因:
rets = [{'id':1},{"id":2},{"id":3}] context = {}
context['count'] = len(rets)
req = []
res = {} for ret in rets:
print(ret)
res['a'] = ret['id']
req.append(res)
print(req)
context['b'] = req
print(context)
打印每次结果:
{'id': 1}
[{'a': 1}]
{'id': 2}
[{'a': 2}, {'a': 2}]
{'id': 3}
[{'a': 3}, {'a': 3}, {'a': 3}]
{'count': 3, 'b': [{'a': 3}, {'a': 3}, {'a': 3}]}
发现每次for循环之后添加到字典中,都会覆盖掉上次添加的数据.
因为字典的增加方式dict1['aaa'] = bbb,这种形式是如果字典理由对应的key就会覆盖掉,没有对应的key就会添加到字典里。
解决办法:
rets = [{'id':1},{"id":2},{"id":3}] context = {}
context['count'] = len(rets)
req = [] for ret in rets:
res = {}
print(ret)
res['a'] = ret['id']
req.append(res)
print(req)
context['b'] = req
print(context)
每次for循环都将字典初始化,然后再添加数据,就结觉问题了。
打印结果:
{'id': 1}
[{'a': 1}]
{'id': 2}
[{'a': 1}, {'a': 2}]
{'id': 3}
[{'a': 1}, {'a': 2}, {'a': 3}]
{'count': 3, 'b': [{'a': 1}, {'a': 2}, {'a': 3}]}
结束!
最新文章
- 初入网络系列笔记(1)TCP/IP基础
- Android应用程序“.R文件”消失怎么办
- SaundProgressBar
- 转载收藏之用 - 微信公众平台开发教程(六):了解MessageHandler
- Linux用户基础
- 加载静态界面----,要不要会加载cookie和页面参数
- 关于python字符串基本操作
- Java基础方法整理
- 一起学Hive——使用MSCK命令修复Hive分区
- Linux 之 AT&;T汇编语言 mov、add、sub指令、数据段
- ChIP-seq实战 | 染色质免疫共沉淀技术 | ATAC-seq | 染色质开放性测序技术
- android 点击数字跳转到电话界面
- SpringMVC系列(十六)Spring MVC与Struts2的对比
- 原生js(三)
- Log4j 2.0 使用说明(1) 之HelloWorld
- linux下执行Python项目,crontab不能定时执行任务
- LeetCode Find Peak Element [TBD]
- C# 文件操作 常用的类
- 2017.2.21 activiti实战--第十三章--流量数据查询与跟踪(一)查询接口介绍及运行时数据查询
- flex设置默认字体为微软雅黑