解决python给列表里添加字典时被最后一个覆盖的问题
如下所示:
>>> item={} ; items=[] #先声明一个字典和一个列表,字典用来添加到列表里面 >>> item['index']=1 #给字典赋值 >>> items.append(item) >>> items [{'index': 1}] #添加到列表里面复合预期 >>> item['index']=2 #现在修改字典 >>> item {'index': 2} #修改成功 >>> items.append(item) #将修改后的新字典添加到列表 >>> items #按预期应该是[{'index': 1}, {'index': 2}] [{'index': 2}, {'index': 2}] #找一下原因: >>> id(item),id(items[0]),id(items[1]) (3083974692L, 3083974692L, 3083974692L) 可以看到item,items[0],items[1]都指向同一个对象,实际上是列表在多次添加(引用)同一个字典。
一种解决的办法:
>>> items=[] >>> for i in range(3): ... item={} #每次都重新声明一个新字典 ... item['index']=i ... items.append(item) ... id(item) ... 3084185084L 3084183588L 3084218956L >>> items [{'index': 0}, {'index': 1}, {'index': 2}] >>>
以上这篇解决python给列表里添加字典时被最后一个覆盖的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。
相关推荐
-
对python字典过滤条件的实例详解
如下所示: d = { 'a': '0.0000', 'b': '1.2' } d_tmp = dict((key, value) for key, value in d.items() if float(value) > 0) print(d_tmp) output: {'b': '1.2'} 以上这篇对python字典过滤条件的实例详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们.
-
对python列表里的字典元素去重方法详解
如下所示: def list_dict_duplicate_removal(): data_list = [{"a": "123", "b": "321"}, {"a": "123", "b": "321"}, {"b": "321", "a": "123"}] run
-
在Python中字典根据多项规则排序的方法
我们做登录的时候经常会使用到,验证手机号是否正确.向手机发送验证码倒计时60s的问题,我们改如何解决呢?让我们一起来探讨一下吧.如下图: 首先,我们先说说判断手机号码是否正确的问题吧,我的想法是给字符串添加一个分类,然后写上这样的代码: + (BOOL)valiMobile:(NSString *)mobile{ if (mobile.length != 11){ //判断手机号码是否为11位 return NO;
-
Python字典循环添加一键多值的用法实例
循环写入字典key.value.删除指定的键值对: 原文本'jp_url.txt'每行元素以逗号分隔: host_key,product_id,product_name,cont_start,cont_end ah2.zhangyue.com,100002,掌阅,bookId=,&startChapterId ih2.ireader.com,100002,掌阅,bid=,& www.ireader.com,100002,掌阅,&bid=,&cid m.zhangyue.co
-
解决python字典对值(值为列表)赋值出现重复的问题
可能很少有人遇到这个问题,网上也没找到,这里记录一下,希望也可以帮到其他人. 问题描述:假设有一个字典data,其键不定,可能随时添加键(这不是关键),某一个键下面对应的值为一个长度为10的list,初始化为0,然后我想修改某些键下面的列表中的某一个值,比如data有一个键'k',对应的值为[0,0,0,0,0,0,0,0,0,0],现在我想把键'k'对应的列表的第三个数改成3,即[0,0,3,0,0,0,0,0,0,0],可是意外的事情发生了,如果data还有一个键'k1',假设其值为[0,0
-
浅谈Python 列表字典赋值的陷阱
今天在用python刷leetcode 3Sum problem时,调入到了一个大坑中,检查半天并没有任何逻辑错误,但输出结果却总是不对,最终通过调试发现原来python中list和dict类型直接赋值竟然是浅拷贝!!!因此,在实际实验中,若要实现深拷贝,建立新list或dict,使新建的list或dict变量和以前的变量只是具有相同的值,但是却具有不同的存储地址,保证在改变以前的list变量的时候,不会对新的list产生任何影响. python中的深拷贝的实现需要通过copy.deepcopy
-
关于python之字典的嵌套,递归调用方法
一 字典的嵌套 在机器学习实战决策树部分,生成决策树时用到了字典的嵌套. >>>s1={'no surface':{}} >>>s1['no surfacce'][0]='no' >>>s1 {'no surface':{0:'no'}} >>>s2={'flipper':{}} >>>s2['flipper'][0]='no' >>>s2['flipper'][1]='yes' >>&
-
python 实现图片旋转 上下左右 180度旋转的示例
如下所示: #首先建好一个数据_ud文件夹 import PIL.Image as img import os path_old = "C:/Users/49691/Desktop/数据/" path_new = "C:/Users/49691/Desktop/数据_ud/" filelist = os.listdir(path_old) total_num = len(filelist) print(total_num) for i in range(total_
-
Python对象与引用的介绍
对象 Python 中,一切皆对象.每个对象由:标识(identity).类型(type).value(值)组成. 1. 标识用于唯一标识对象,通常对应于对象在计算机内存地址.使用内置函数 id(obj)可返回对象 obj 的标识. 2. 类型用于表示对象存储的"数据"的类型.类型可以限制对象的取值范围以及可执行的操作.可以使用 type(obj)获得对象的所属类型. 3. 值表示对象所存储的数据的信息.使用 print(obj)可以直接打印出值. 对象的本质:一个内存块,拥有特定的值
-
Python字典的核心底层原理讲解
字典对象的核心是散列表.散列表是一个稀疏数组(总是有空白元素的数组),数组的每个单元叫做 bucket.每个 bucket 有两部分:一个是键对象的引用,一个是值对象的引用.所有 bucket 结构和大小一致,我们可以通过偏移量来读取指定 bucket.下面通过存储与获取数据的过程介绍字典的底层原理. 存储数据的过程 例如,我们将'name' = '张三' 这个键值对存储到字典map中,假设数组长度为8,可以用3位二进制表示. >>> map = {} >>> map
随机推荐
- Oracle数据库下载及安装图文操作步骤
- 使用重写url机制实现验证码换一张功能
- TypeOf这些知识点你了解吗
- phpExcel导出大量数据出现内存溢出错误的解决方法
- python使用三角迭代计算圆周率PI的方法
- python统计文本文件内单词数量的方法
- php开发环境配置记录
- 实现释放CentOS系统内存的Shell脚本分享
- ajax设置async校验用户名是否存在的实现方法
- 详解webpack 配合babel 将es6转成es5 超简单实例
- PowerShell中按修改时间查找文件的方法
- jquery 元素相对定位代码
- js对象之JS入门之Array对象操作小结
- javaScript 动态访问JSon元素示例代码
- [ASP]精华代码
- 浅谈SpringMVC jsp前台获取参数的方式 EL表达式
- Python re 模块findall() 函数返回值展现方式解析
- springmvc+ajax+formdata上传图片代码实例
- C++编程产生指定范围内的随机数
- python 借助numpy保存数据为csv格式的实现方法