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
		集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. 关系测试, ... 
随机推荐
- Django 使用allauth报错
			一:报错 RuntimeError: Model class django.contrib.sites.models.Site doesn't declare an explicit app_labe ... 
- git代理设置方法
			客户公司办公,上外网需要代理,临时查一下资料,记录一下: 1.设置代理: git config --global http.proxy http://IP:Port 2.代理设置完成后,查看设置是否生 ... 
- No input file specified的解决方法
			(一)IIS Noinput file specified 方法一:改PHP.ini中的doc_root行,打开ini文件注释掉此行,然后重启IIS 方法二:请修改php.ini找到; cgi.for ... 
- MySQL select * 和把所有的字段都列出来,哪个效率更高?
			MySQL select * 和把所有的字段都列出来,哪个效率更高 答案是:如何,都不推荐使用 SELECT * FROM (1)SELECT *,需要数据库先 Query Table Metadat ... 
- SqlDbx远程链接DB2数据库
			1.首先下载IBM的IBM Data Server Client,百度云链接:http://pan.baidu.com/s/1kVBVjan 密码:2gtz 2.安装好客户端之后,打开cmd,运行db ... 
- 洛谷 P2935 [USACO09JAN]最好的地方Best Spot
			题目描述 Bessie, always wishing to optimize her life, has realized that she really enjoys visiting F (1 ... 
- codevs 1606 台阶
			时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 话说某牛家门外有一台阶,这台阶可能会很高(总层数<=1000000). 这 ... 
- UVALive 4080 Warfare And Logistics (最短路树)
			很多的边会被删掉,需要排除一些干扰进行优化. 和UVA - 1279 Asteroid Rangers类似,本题最关键的地方在于,对于一个单源的最短路径来说,如果最短路树上的边没有改变的话,那么最短路 ... 
- 47.Number of Islands(岛的数量)
			Level: Medium 题目描述: Given a 2d grid map of '1's (land) and '0's (water), count the number of islan ... 
- SniperOj-shorter-shellcode-x86
			shell-storm 这里可以有一些可以用的shellcode,不过自己写才是biner的骄傲 /奋斗 0x00 不会写shellcode(和一条咸鱼有什么区别/哭) 0x01 这题目前有俩种解法 ... 
