一、集合:类似列表,元组的存储数据容器,不同点是不可修改,不可重复.无序排列.

1.创建集合:

(1).set1 = {'abby', 'eric'}

result:{'eric', 'abby'}

(2).set2 = set({'abby', 'eric'})

result:{'abby', 'eric'}

2.增

set1 = {'abby','eric','allan','davy','skye'}

(1).set1.add('west')

result:{'west','abby','eric','allan','davy','skye'}

(2).set1.update('abc')#迭代新增

result:{'west','abby','a','eric','allan','c','davy','b','skye'}

3.删

set1 = {'abby','eric','allan','davy','skye'}

(1).set1.remove('abby')#指定删除

result:{'eric','allan','davy','skye'}

(2).set1.pop()#随机删除

result:{'abby','eric','allan','skye'}

(3).set clear()#清空集合

result:set()

(4).del set1#从内存删除集合

result:name 'set1' is not defined

4.关系测试:

set1 = {1,2,3,4,5}

set2 = {4,5,6,7,8}

(1).交集:

1:print(set1 & set2)

2:print(set1.intersection(set2)

result:{4,5}

(2).并集

1:print(set1 | set2)

2:print(set1.union(set2)

result:{1, 2, 3, 4, 5, 6, 7, 8}

(3).反交集

1:print(set1 ^ set2)

2:print(set1.symmetric_difference(set2)

result:{1, 2, 3, 6, 7, 8}

(4).差集

1:print(set1 - set2)

2:print(set1.difference(set2)

result:{1, 2, 3}

3.print(set2-set1)

4.print(set2.difference(set1)

result:{8, 6, 7}

(5)子集

set1 = {1,2,3}

set2 = {1,2,3,4,5,6}

print(set1 < set2)

print(set1.issubset(set2))

result:True

(5)超集

print(set2 > set1)

print(set2.issuperset(set1))

result:True

(6)冻结,不可变的数据类型

set1 = {1,2,3}

set3 = frozenset(set1)

result:frozenset({1, 2, 3})

面试题:list去重

l1 = [1,1,2,3,4,4,3,2,1,5,5]

set1 = set(l1)

l2 = list(set1)

print(l2)

二、深浅copy

1. 赋值运算

l1 = [1,2,3]

l2 = l1

l1.append(666)

print(l2)

print(id(l1))

print(id(l2))

result:

[1, 2, 3, 666]

2724735509128

2724735509128

2.浅copy

test01:

l1 = [1,2,3]

l2 = l1.copy()

l1.append(666)

print(l2)

result:[1, 2, 3]

test02:

l1 = [1,2,3,[22,]]

l2 = l1.copy()

l1.append(666)

print(l1,l2)

result:[1, 2, 3, [22], 666] [1, 2, 3, [22]]

test03:

l1 = [1,2,3,[22,]]

l2 = l1.copy()

l1[-1].append('abby')

print(l1,l2)

print(id(l1))

print(id(l2))

print(id(l1[-1]))

print(id(l2[-1]))

result:

[1, 2, 3, [22, 'abby']] [1, 2, 3, [22, 'abby']]
2586054582984
2586055807688
2586054582920
2586054582920

3.深copy

需要copy模块

import copy

l1 = [1,2,3,[22,]]

l2 = copy.deepcopy(l1)

l1.append(666)

print(l2)

result:[1, 2, 3, [22]]

总结深浅copy:都是copy,浅copy复制第一层独立存在,第二层与复制对象共同拥有.深copy复制所有层并且独立存在

面试题:

l1 = [1,2,3,[22,33]]

l2 = l1[:]

l1.append(666)

print(l2)

result:[1, 2, 3, [22, 33]]

总结:切片属于浅copy

三、基础数据补充

1.数据类型的转换

# str ---> list

s1 = 'abby eric west'

l1 = s1.split()

print(l1)

result:['abby', 'eric', 'west']

l1 = ['abby', 'eric', 'west']

s2 = ' '.join(l1)

print(s2)

result:abby eric west

# tuple <---> list

l1 = [1,2,3]

tu1 = tuple(l1)

print(tu1)

result:(1, 2, 3)

tu2 = (0,2,3)

l1 = list(tu2)

print(l1)

result:[0, 2, 3]

# dic ---> list

dic1 = {'name': 'alex', 'age': 1000}

l1 = list(dic1)

print(l1)

result:['name', 'age']

bool转换

0 " [] () {} set() ---> bool: False

四、enumerate枚举

字典用法:

dic01 = {'key1': 'value1','key2': 'value2', 'k3':'v3', 'name': 'abby'}

1.for i in enumerate(dic01,1):#1为索引起始位

  print(i)

result:

(1, 'key1')
(2, 'key2')
(3, 'k3')
(4, 'name')

2.for a,b in enumerate(dic01,1):

  print(a,b)

result:

1 key1
2 key2
3 k3
4 name

列表:li01 = [1,2,3,4,5,6,7,8]

for i in enumerate(li01,1):

  print(i)

result:

(1, 1)
(2, 2)
(3, 3)
(4, 4)
(5, 5)
(6, 6)
(7, 7)
(8, 8)

for a,b in enumerate(li01,1):

  print(a,b)

result:

1 1
2 2
3 3
4 4
5 5
6 6
7 7
8 8

python之路(集合,深浅copy,基础数据补充)的更多相关文章

  1. Python基础学习Day7 基础数据类型的扩展 集合 深浅copy

    一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...

  2. python学习笔记三 深浅copy,扩展数据类型(基础篇)

    深浅copy以及赋值 对于字符串和数字而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. import copy n1 = #n1 = 'hahahaha' #赋值n2 = n1#浅co ...

  3. Python 集合 深浅copy

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

  4. python集合深浅copy

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

  5. 003_python的str切片,str常用操作方法,for循环,集合,深浅copy

    基础数据类型 基础数据类型,有7种类型,存在即合理. 1.int 整数 主要是做运算的 .比如加减乘除,幂,取余  + - * / ** %... 2.bool布尔值 判断真假以及作为条件变量 3.s ...

  6. python之路(三)-深浅拷贝

    深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝指拷贝数据集合的所有层.所 ...

  7. NO.3:自学python之路------集合、文件操作、函数

    引言 本来计划每周完成一篇Python的自学博客,由于上一篇到这一篇遇到了过年.开学等杂事,导致托更到现在.现在又是一个新的学期,春天也越来越近了(冷到感冒).好了,闲话就说这么多.开始本周的自学Py ...

  8. 集合 & 深浅copy

    集合: 特点:集合是可变的数据类型,但他里面的元素必须是不可变的数据类型,无序,不可重复. 创建: set1 = set({1,2,3}) 或者直接创建set2 = {1,2,3} 集合的增删查: 增 ...

  9. python列表中的深浅copy

    列表中的赋值和平常的赋值是不一样的,看下面的代码: In [1]: a = 1 In [2]: b = a In [3]: a Out[3]: 1 In [4]: b Out[4]: 1 In [5] ...

随机推荐

  1. SSL公钥证书传递进行隐匿传输数据

    title: 使用X.509公钥证书传递进行隐匿传输数据 date: 2018-02-11 17:47:50 tags: --- 使用X.509公钥证书传递进行隐匿传输数据 看到国外一篇有关于在ssl ...

  2. GPU 版 TensorFlow failed to create cublas handle: CUBLAS_STATUS_ALLOC_FAILED

    原因: 使用 GPU 版 TensorFlow ,并且在显卡高占用率的情况下(比如玩游戏)训练模型,要注意在初始化 Session 的时候为其分配固定数量的显存,否则可能会在开始训练的时候直接报错退出 ...

  3. docker:搭建ELK 开源日志分析系统

    ELK 是由三部分组成的一套日志分析系统, Elasticsearch: 基于json分析搜索引擎,Elasticsearch是个开源分布式搜索引擎,它的特点有:分布式,零配置,自动发现,索引自动分片 ...

  4. Matplotlib数据可视化从入门到精通(持续更新)

    目录 前言 如何添加标题-title 如何添加文字-text 如何添加注释-annotate 如何设置坐标轴名称-xlabel/ylabel 如何添加图例-legend 如何调整颜色-color 如何 ...

  5. .NET Core之单元测试(四):Fluent Assertions的使用

    目录 什么是Fluent Assertions 待测试API 测试用例 什么是Fluent Assertions Fluent Assertions 是 .NET 平台下的一组扩展方法,用于单元测试中 ...

  6. Arm开发板+Qt学习之路-析构函数和对话框一起时

    先记录一下代码 一:先将指针释放掉,在显示对话框 void MainWindow::canResponseError(SendCanMsgThread *sendCanMsgThread ){ std ...

  7. opencv —— calcHist、minMaxLoc 计算并绘制图像直方图、寻找图像全局最大最小值

    直方图概述 简单来说,直方图就是对数据进行统计的一种方法,这些数据可以是梯度.方向.色彩或任何其他特征.它的表现形式是一种二维统计表,横纵坐标分别是统计样本和该样本对应的某个属性的度量. 计算直方图: ...

  8. MySQL面试笔试题集-BAT

    01.MySQL技术特点? Mysql数据库软件是一个客户端或服务器系统,支持各种客户端程序和库的多线程SQL服务器.不同的后端.广泛的应用程序编程接口和管理工具 02.MySQL默认端口号? 330 ...

  9. BOS只读状态修改

    update T_META_OBJECTTYPE set FSUPPLIERNAME ='PAEZ',FPACKAGEID =null

  10. linux设置服务器时间

    在 Linux 机器上有两种时钟: 由内核维持的软件时钟(又称系统时钟)和在机器关机后记录时间的(电池供电的)硬件时钟. 启动的时候, 内核会把系统时钟与硬件时钟同步. 之后, 两个时钟各自独立运行. ...