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. keil_rtx调试技巧

    超级循环结构的程序调试一般依赖于断点,单步,查看变量和内存变量(keil中的Memory Window 或者 Watch window):而带微操作系统的程序由于加了这个中间层调试方法可能传统的有些区 ...

  2. [译]Understanding ECMAScript6 对象

    对象 ECMAScript6将大量精力聚焦在提升对象的实用性性上.聚焦的意义在于JavaScript中几乎每一个值是由对象中的某种类型表示.此外,在一个普通的JavaScript程序中使用对象的数量持 ...

  3. Unity Shader入门精要学习笔记 - 第16章 Unity中的渲染优化技术

    转自冯乐乐的 <Unity Shader 入门精要> 移动平台的特点 为了尽可能一处那些隐藏的表面,减少overdraw(即一个像素被绘制多次),PowerVR芯片(通常用于ios设备和某 ...

  4. 如何 发布一个 arcgis 服务

    1,打开arcgis, 加载一个图层 后然后如下操作

  5. user-select详解

    语法: user-select:none | text | all | element 默认值:text 适用于:除替换元素外的所有元素 继承性:无 动画性:否 计算值:指定值 取值: none: 文 ...

  6. Android使用MediaRecorder和Camera实现视频录制及播放功能整理

    转载请注明出处:http://blog.csdn.net/woshizisezise/article/details/51878566 这两天产品经理向我丢来一个新需求,需要在项目里添加一个视频录制的 ...

  7. 使用office 365打开excel文件报错,提示“向程序发送命令时出现问题”

    我买了一套正版的office 365装在我的windows10 上.但是每次打开excel都会报错,如图一.求教了微软技术人员,他们给出了以下办法: 图一 方法一: 修复安装Office ====== ...

  8. Objective-C相关Category的收集(更新)

    Categories是给你得不到源码的classes增加功能的一种方法.这个页面收集一些相关的Category,并且持续更新,你可以订阅关注.作者是Fille ?str?m,是@ IMGNRY的联合创 ...

  9. python之文件读写操作(r/r+/rb/w/w+/wb/a/a+/ab)的作用

    'r':只读.该文件必须已存在. 'r+':可读可写.该文件必须已存在,写为追加在文件内容末尾. 'rb':表示以二进制方式读取文件.该文件必须已存在. 'w':只写.打开即默认创建一个新文件,如果文 ...

  10. Python基础篇 -- 部分练习题

    实现一个整数加法计算器(两个数相加): 如:content = input("请输入内容:") 用户输入:5+9或5+ 9或5 + 9(含空白),然后进行分割转换最终进行整数的计算 ...