7,数据类型转换,set 集合,和深浅copy
str转换成list 用split
list转换成str 用join
tuple转换成list
tu1 = (1,2,3)
li = list(tu1)(强转)
tu2 = tuple(li)(强转)
dic转换成list
c2 = list(dic)
各种数据类型转换成bool
0,'',[],(),{}, set() 转成bool都是Fasle
在循环列表或者字典删除元素的过程中,有可能会影响结果,有可能会报错。
报错信息如下:
RuntimeError: dictionary changed size during iteration
解释:运行时错误:字典在迭代期间更改了大小。
集合
set2 = {11,11,11,44} set去重
print(set2)
l1 = [11, 11, 22, 22, 33, 33, 33, 44] 列表去重
l2 = list(set(l1))
l2.sort()
print(l2)
增(add,update)
set1 = {'alex', 'WuSir', 'RiTiAn', 'egon', 'barry'}按元素增加(不能切片,不能索引,不能不长)
set1.add('zhangyajie')
print(set1)
set1 = {'alex', 'WuSir', 'RiTiAn', 'egon', 'barry'} 迭代添加
set1.update(['asd'])
print(set1)
删(pop,remove,clear,del)
set1 = {'alex', 'WuSir', 'RiTiAn', 'egon', 'barry'}
print(set1.pop()) #随机删除
set1.remove('alex') #按元素删除
print(set1)
set1.clear() #清空列表
print(set1)
del set1 #删除列表
print(set1)
查(for)
set1 = {'alex', 'WuSir', 'RiTiAn', 'egon', 'barry'}
li = []
for i in set1:
if i.startswith('a') or i.endswith('x'):
li.append(i)
print(li)
交集(intersetion 和 &)
set1 = {1, 2, 3, 4, 5}
set2 = {4, 5, 6, 7, 8}
set3 = set1 & set2
print(set3)
print(set1.intersection(set2))
并集 | 和 union
print(set1 | set2)
print(set1.union(set2))
差集 difference -
set1 = {1, 2, 3, 4, 5}
set2 = {4, 5, 6, 7, 8}
print(set1.difference(set2)) # set1 独有
print(set2.difference(set1)) # set2 独有
print(set1 - set2) #set1独有的
print(set2 - set1) #set2独有的
反差集 ^ 和 symmetric_difference
print(set1 ^ set2)
print(set1.symmetric_difference(set2))
子集
set1 = {1,2,3}
set2 = {1,2,3,4,5,6}
print(set1 > set2) # set1是set2的子集
超集
set1 = {1, 2, 3}
set2 = {1, 2, 3, 4, 5, 6}
print(set2.issuperset(set1))
冻结 set
set1 = frozenset({1,2,3, 'alex'})
print(set1,type(set1))
赋值运算的内存地址比较:
对于赋值运算来说,指向的都是同一个内存地址,一变都变。
l1 = [1, 2, 3]
l2 = l1
l3 = l2
l3.append(666)
print(id(l1))
print(id(l2))
print(id(l3))
print(l3)
print(l2)
print(l1)
深浅copy
浅copy
对于浅copy来说,第一层内存地址是创建新的内存地址(意思就是两个内存地址不一样),第二层开始,共用同一个内存地址,
所以对于第3,4,5,6曾之后,共用的都是同一个内存地址。
l1 = [11,22,33]
l2 = l1.copy()
l1.append(666)
print(id(l1))
print(id(l2))
print(l1)
print(l2)
li = [11, 22, ['barry',[222]]]
l1 = li.copy()
print(id(li))
print(id(l1))
print(id(li[-1]))
print(id(l1[-1]))
深copy
l1 = [11, 22, 33]
l2 = copy.deepcopy(l1)
l1.append(666)
print(l1, id(l1))
print(l2, id(l2))
结果:
[11, 22, 33, 666] 233294746056
[11, 22, 33] 233294657800
深copy,是新建了完全独立的内存空间。
import copy
l1 = [11, 22, ['barry']]
l2 = copy.deepcopy(l1)
l1[2].append('alex')
print(l1,id(l1))
print(l2,id(l2))
print(l1, id(l1[-1]))
print(l2, id(l2[-1]))
7,数据类型转换,set 集合,和深浅copy的更多相关文章
- 数据结构中的列表、元组、字典、集合 ,深浅copy
数据结构:数据结构是计算机存储数据和组织数据的方式.数据结构是指相互之间存在一种或多种特定关系的数据元素的集合.在python中主要的数据类型统称为容器. 而序列(如列表.元组).映射(如字典).集合 ...
- 基础数据类型的坑和集合及深浅copy
一.基础数据类型的坑: 元组: 如果一个元组中,只有一个元素,且没有逗号,则该"元组"与里面的数据的类型相同. # 只有一个数据,且没有逗号的情况: print(tu1,type( ...
- 第八天- 基础数据操作补充 集合set 深浅拷贝
字符串的操作补充: .join() 方法用于将序列(字符串/列表/元组/字典)中的 元素 以指定的字符连接生成一个新的字符串 str = "人生苦短我用python!" # 用于字 ...
- python之集合,深浅copy
一. 集合 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...
- python之数据类型补充、集合、深浅copy
一.内容回顾 代码块: 一个函数,一个模块,一个类,一个文件,交互模式下,每一行就是一个代码块. is == id id()查询对象的内存地址 == 比较的是两边的数值. is 比较的是两边的内存地址 ...
- day 07 数据类型,集合,深浅copy
1.day 06 内容回顾 小数据池 int :-5-256 str:特殊字符 ,*20 ascii:8位 1字节 表示一个字符 unicode:32位 4个字节 , 表示一个字符 字节表示8位表示一 ...
- Python学习之路基础篇--07Python基础+编码、集合 和 深浅Copy
1 小数据池(节省内存) 只有数字和字符串中内存,储存在同一个内存地址中 数字的范围在-5~256中,字符串有以下两个特点:不能含有特殊字符,还有就s*20 不是同一个地址,而要*21就不是了 2 编 ...
- python 的基础 学习 第八天数据类型的补充 ,集合和深浅copy
1,数据类型的补充: 元组()tuple,如果只有元素,并且没有逗号,此元素是什么数据类型,该表达式就是什么数据类型. tu = ('rwr') print(tu,type(tu)) tu = ('r ...
- python-基础数据类型,集合及深浅copy
一 数据类型定义及分类 我们人类可以很容易的分清数字与字符的区别,但是计算机并不能呀,计算机虽然很强大,但从某种角度上看又很傻,除非你明确的告诉它,1是数字,“汉”是文字,否则它是分不清1和‘汉’的区 ...
- Day5 集合的深浅copy
集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. 关系测试, ...
随机推荐
- jsp动态图片页面基础
1. 什么是动态网页? 动态网页是指在服务器端运行的程序或者网页,它们会随不同客户.不同时间,返回不同的网页. 注意:在静态网页中插入flash ,虽然flash是在动的,但是并不是说这个网页就是动态 ...
- BundleConfig包含js,css失败
今天在做mvc项目的时候,引入了bootstrap样式.但是包含css和js的时候出错了 于是我查阅资料,好多人都说后缀名前面不能包含".",于是我把min前面的".&q ...
- phpstorm类似sublime ctrl + alt +down多光标下移
http://blog.jetbrains.com/phpstorm/2014/03/working-with-multiple-selection-in-phpstorm-8-eap/ 评论有一条回 ...
- iOS 循环引用解决方案
一.BLOCK 循环引用 一般表现为,某个类将block作为自己的属性变量,然后该类在block的方法体里面又使用了该类本身.构成循环引用. // 定义 block 的时候,会对外部变量做一次 cop ...
- github入门之配置github本地仓库--2
*前期准备工作 创建github账户 github地址 1.设置SSH_Key ssh-keygen -t rsa -C "你的邮箱" 2.查看秘钥 cat ~/.ssh/id_r ...
- MySQL检查死锁简介
- jmeter中登录和提交收银出现的错误
登录出现的错误 登录界面如图所示: 为了防止登录跳转的问题response code 302的问题,要设置 2.提交收银界面 当系统设置必须传送jison格式时,要在HTTP Header Manag ...
- decompressedResponseImageOfSize:completionHandler:]_block_invoke
原因: It turns out the linker error was caused by the CGImageSourceCreateWithData call. And the root ...
- Go 1.4 正式版发布,官方正式支持 Android
Go 1.4 正式发布啦,是第五个 Go 的稳定版本,与上一个稳定版本 Go 1.3 相隔 6 个月.Go 1.4 包括一些小的语言改进,支持更多的操作系统和处理器架构:改进了工具链和库.同时,Go ...
- UVA 11374 Airport Express (最短路)
题目只有一条路径会发生改变. 常见的思路,预处理出S和T的两个单源最短路,然后枚举商业线,商业线两端一定是选择到s和t的最短路. 路径输出可以在求最短路的同时保存pa数组得到一棵最短路树,也可以用di ...