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的更多相关文章

  1. 数据结构中的列表、元组、字典、集合 ,深浅copy

    数据结构:数据结构是计算机存储数据和组织数据的方式.数据结构是指相互之间存在一种或多种特定关系的数据元素的集合.在python中主要的数据类型统称为容器. 而序列(如列表.元组).映射(如字典).集合 ...

  2. 基础数据类型的坑和集合及深浅copy

    一.基础数据类型的坑: 元组: 如果一个元组中,只有一个元素,且没有逗号,则该"元组"与里面的数据的类型相同. # 只有一个数据,且没有逗号的情况: print(tu1,type( ...

  3. 第八天- 基础数据操作补充 集合set 深浅拷贝

    字符串的操作补充: .join() 方法用于将序列(字符串/列表/元组/字典)中的 元素 以指定的字符连接生成一个新的字符串 str = "人生苦短我用python!" # 用于字 ...

  4. python之集合,深浅copy

    一. 集合 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...

  5. python之数据类型补充、集合、深浅copy

    一.内容回顾 代码块: 一个函数,一个模块,一个类,一个文件,交互模式下,每一行就是一个代码块. is == id id()查询对象的内存地址 == 比较的是两边的数值. is 比较的是两边的内存地址 ...

  6. day 07 数据类型,集合,深浅copy

    1.day 06 内容回顾 小数据池 int :-5-256 str:特殊字符 ,*20 ascii:8位 1字节 表示一个字符 unicode:32位 4个字节 , 表示一个字符 字节表示8位表示一 ...

  7. Python学习之路基础篇--07Python基础+编码、集合 和 深浅Copy

    1 小数据池(节省内存) 只有数字和字符串中内存,储存在同一个内存地址中 数字的范围在-5~256中,字符串有以下两个特点:不能含有特殊字符,还有就s*20 不是同一个地址,而要*21就不是了 2 编 ...

  8. python 的基础 学习 第八天数据类型的补充 ,集合和深浅copy

    1,数据类型的补充: 元组()tuple,如果只有元素,并且没有逗号,此元素是什么数据类型,该表达式就是什么数据类型. tu = ('rwr') print(tu,type(tu)) tu = ('r ...

  9. python-基础数据类型,集合及深浅copy

    一 数据类型定义及分类 我们人类可以很容易的分清数字与字符的区别,但是计算机并不能呀,计算机虽然很强大,但从某种角度上看又很傻,除非你明确的告诉它,1是数字,“汉”是文字,否则它是分不清1和‘汉’的区 ...

  10. Day5 集合的深浅copy

    集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. 关系测试, ...

随机推荐

  1. 085 Maximal Rectangle 最大矩形

    给定一个填充了 0 和 1 的二进制矩阵,找到最大的只包含 1 的矩形并返回其面积.例如,给出以下矩阵:1 0 1 0 01 0 1 1 11 1 1 1 11 0 0 1 0返回 6 详见:http ...

  2. 118 Pascal's Triangle 帕斯卡三角形 杨辉三角形

    给定 numRows, 生成帕斯卡三角形的前 numRows 行.例如, 给定 numRows = 5,返回[     [1],    [1,1],   [1,2,1],  [1,3,3,1], [1 ...

  3. 105 Construct Binary Tree from Preorder and Inorder Traversal 从前序与中序遍历序列构造二叉树

    给定一棵树的前序遍历与中序遍历,依据此构造二叉树.注意:你可以假设树中没有重复的元素.例如,给出前序遍历 = [3,9,20,15,7]中序遍历 = [9,3,15,20,7]返回如下的二叉树:    ...

  4. python学习之调试 错误捕捉及处理

    1 捕捉错误:try except    Err_Case1: pass except    Err_Case2: pass else: 正常情况: finally: 无论是否异常都要 处理的代码 w ...

  5. webpack 精华文章

    最近迁移 webpack1 到 webpack3 碰到了一些问题,还是通过一些文章,解决了问题.在这里做一个备份,方便以后使用. 从零搭建vue2+vue-router2+webpack3工程 Web ...

  6. 前端之CSS常见兼容性问题

    1.双倍浮动BUG: 描述:块状元素设置了float属性后,又设置了横向的margin值,在IE6下显示的margin值要比设置的值大: 解决方案:给float的元素添加 display:inline ...

  7. ubuntu中使用eclipse开发android,logcat显示问题

    〜/工作区/ .metadata / .plugins / org.eclipse.core.runtime / .settings / com.android.ide.eclipse.ddms.pr ...

  8. 最详细的github快速入门教程

    一:下载github 二:安装GitHub 下载之后点击 进行安装过程,安装之后桌面上会有两个图标,如下图 三:新建项目 GitHub是图形界面模式,Git Shell是命令行模式,在Windows系 ...

  9. SQL增删查改语句

    一.增:有4种方法 1.使用insert插入单行数据: 语法:insert [into] <表名> [列名] values <列值> insert into sheet1 va ...

  10. O2O的十八个细分市场,运营模式如何?

    社区O2O,这个行业也被媒体热炒有三年多时间了,有没有做的还算不错的案例呢?万科.龙湖.恒大.保利.易居中国.彩生活.拉卡拉.顺丰?哪个可以称得上是成功案例?战略变来变去,方向换来换去,基本上都是雷声 ...