for循环将字典添加到列表中出现覆盖前面数据的问题
出现问题:
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}]}
结束!
for循环将字典添加到列表中出现覆盖前面数据的问题的更多相关文章
- python中字典排序,列表中的字典排序
python中字典排序,列表中的字典排序 一.使用python模块:operator import operator #首先要导入模块operator x = {1:2, 3:4, 4:3, 2:1, ...
- python中列表排序,字典排序,列表中的字典排序
#-*- encoding=utf-8 -*- # python3代码 import operator 一. 按字典值排序(默认为升序) x = {1:2, 3:4, 4:3, 2:1, 0:0} 1 ...
- knockout更新列表中的某条数据,knockout.js绑定数组时更新其中一条数据
knockout是一款前端实现MVVM的JS框架,仅knockout.js一个47kb的文件,相当实用,做前端无刷新页面,快速实现JS与HTML数据交互. knockout目前最新版:knockout ...
- python删除列表中得重复得数据
解决思想:将列表转换为 集合,利用集合删除重复数据得特性删除重复数据,然后将集合转换为列表 #删除列表中得重复元素 def delect_1 (lt): s = set(lt) lt = list(s ...
- 遍历存储所有物体添加到列表中(使用GameObject.activeSelf进行判断)
//存储菜单列表 List<GameObject> subMenu = new List<GameObject>(); //存储所有子菜单 public void StoreS ...
- Python列表中的字典按照该字典下的键值进行排序
列表中的字典按照该字典下的键值进行排序 这算是排序中比较复杂的一种情况吧,多重嵌套,按照某种规则进行排序.如下面这个json(注:这里这是该列表中的一个项): [ { "stat" ...
- JavaScript数据结构——集合、字典和散列表
集合.字典和散列表都可以存储不重复的值. 在集合中,我们感兴趣的是每个值本身,并把它当作主要元素.在字典和散列表中,我们用 [键,值] 的形式来存储数据. 集合(Set 类):[值,值]对,是一组由无 ...
- JavaScript数据结构——字典和散列表的实现
在前一篇文章中,我们介绍了如何在JavaScript中实现集合.字典和集合的主要区别就在于,集合中数据是以[值,值]的形式保存的,我们只关心值本身:而在字典和散列表中数据是以[键,值]的形式保存的,键 ...
- 在GridView列表中使用图片显示记录是否包含附件
在我的前面很多文章中,都介绍过通用附件模块的管理,本篇随笔主要介绍在一些应用模块中的列表展示中,包含附件的记录,在GridView列表界面中使用图标来快速显示是否有附件的情况. 1.通用附件模块的应用 ...
随机推荐
- Spring Boot中CrudRepository与JpaRepository Dao中JpaRepository和JpaSpecificationExecutor查询
原文地址 https://blog.csdn.net/xuemengrui12/article/details/80525227?utm_source=blogxgwz0 https://www.i ...
- Mentor面向智能家居的IoT方案
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/wireless_com/article/details/82111734 眼下有各种智能家居的自己主 ...
- 从Encoder到Decoder实现Seq2Seq模型
https://zhuanlan.zhihu.com/p/27608348 更新:感谢@Gang He指出的代码错误.get_batches函数中第15行与第19行,代码已经重新修改,GitHub已更 ...
- 在Windows上使用CMake+CMakeLists.txt生成VS项目编译DlibDotnet库
一.下次源库 地址:https://github.com/takuya-takeuchi/DlibDotNet 二.下载CMake3以上版本 地址:https://cmake.org/download ...
- Spark机器学习(9):FPGrowth算法
关联规则挖掘最典型的例子是购物篮分析,通过分析可以知道哪些商品经常被一起购买,从而可以改进商品货架的布局. 1. 基本概念 首先,介绍一些基本概念. (1) 关联规则:用于表示数据内隐含的关联性,一般 ...
- C# System.Collections.Stack
using System; using System.Collections; public class SamplesStack { public static void Main() { // C ...
- sqlserver修改主键为自增
使用PowerDesigner创建一张表, 拷贝建表语句发现ID不是自增的, 以下是修改语句: ALTER TABLE USER_JOB_EXE_REC DROP COLUMN id; , ); 注: ...
- 如何获取ubuntu源码包里面的源码?
ubuntu 源仓库说明 1.在获取源码包之前,确保在软件源配置文件/etc/apt/sources.list中添加了deb-src项 vim /etc/apt/sources.list # # de ...
- python gb2312 转换为 utf-8
url = "" headers = { "Host":"www.chinanews.com", "User-Agent" ...
- SNF快速开发平台MVC-甘特图
上个月做了CS框架的甘特图样例,本月框架组人员又实现了BS的甘特图效果,而且效果也很不错哦 图形框可以直接拖拽调整时长时间: 新增节点: