python之路(集合,深浅copy,基础数据补充)
一、集合:类似列表,元组的存储数据容器,不同点是不可修改,不可重复.无序排列.
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,基础数据补充)的更多相关文章
- Python基础学习Day7 基础数据类型的扩展 集合 深浅copy
一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...
- python学习笔记三 深浅copy,扩展数据类型(基础篇)
深浅copy以及赋值 对于字符串和数字而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. import copy n1 = #n1 = 'hahahaha' #赋值n2 = n1#浅co ...
- Python 集合 深浅copy
一,集合. 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...
- python集合深浅copy
一,集合. 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...
- 003_python的str切片,str常用操作方法,for循环,集合,深浅copy
基础数据类型 基础数据类型,有7种类型,存在即合理. 1.int 整数 主要是做运算的 .比如加减乘除,幂,取余 + - * / ** %... 2.bool布尔值 判断真假以及作为条件变量 3.s ...
- python之路(三)-深浅拷贝
深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝指拷贝数据集合的所有层.所 ...
- NO.3:自学python之路------集合、文件操作、函数
引言 本来计划每周完成一篇Python的自学博客,由于上一篇到这一篇遇到了过年.开学等杂事,导致托更到现在.现在又是一个新的学期,春天也越来越近了(冷到感冒).好了,闲话就说这么多.开始本周的自学Py ...
- 集合 & 深浅copy
集合: 特点:集合是可变的数据类型,但他里面的元素必须是不可变的数据类型,无序,不可重复. 创建: set1 = set({1,2,3}) 或者直接创建set2 = {1,2,3} 集合的增删查: 增 ...
- python列表中的深浅copy
列表中的赋值和平常的赋值是不一样的,看下面的代码: In [1]: a = 1 In [2]: b = a In [3]: a Out[3]: 1 In [4]: b Out[4]: 1 In [5] ...
随机推荐
- 业余无线电A类考试准备笔记
在线模拟自测地址:https://liunan.github.io/crac/ 共361题,到LK0074 1004/2890行 Key Word: 要合法 要服从管理 Note: 无线电管理 最高法 ...
- 10-SpringMVC04
FreeMarker 1.入门案例 1. 导包:freemarker.jar 2. 需要创建模板文件的路径:src/main/resources/template 3. 创建一个模板对象:hello. ...
- Ikuai路由安装及简单配置 v1.0
第一部分:创建虚拟机: 1.点击创建新的虚拟机 2.选择自定义模式创建(选择经典模式会更友好一些),然后点击下一步 3.下图内容不用管,直接点击下一步: 4.这里是选择安装系统路径.在这里我们 ...
- pytorch --Rnn语言模型(LSTM,BiLSTM) -- 《Recurrent neural network based language model》
论文通过实现RNN来完成了文本分类. 论文地址:88888888 模型结构图: 原理自行参考论文,code and comment: # -*- coding: utf-8 -*- # @time : ...
- k8s系列---StorageClass
介绍这个概念前,需要提前知道存储卷pv/pvc之类的概念. 之前的文章有关于EFK日志系统的介绍,里面的环境是测试环境,完全按照教程一步步的操作,甚至注释掉了持久化存储,当真正线上部署时,又抓虾,打开 ...
- C语言快速排序函数------qsort();
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<conio.h> ty ...
- xmake v2.3.1 发布, 无缝对接其他构建系统
最近对xmake内部做了不少的重构来改进,并且新增了不少实用的新特性,欢迎来体验. 项目源码 官方文档 一些新特性: 一键编译其他构建系统维护的项目,实现无缝对接,并且支持交叉编译(比如autotoo ...
- Windows安装MySQL免安装版
安装环境: win7 64位 IP地址:192.168.2.37 防火墙已经关闭 一.安装MySQL5.7.14免安装版 1.解压文件 2.新建my.ini文件 data文件夹自动生成 my.ini里 ...
- [未完成]ECRound 80
Educational Codeforces Round 80 (Rated for Div. 2)A 大意:寻找x使得等式<=n,若满足情况输出YES否则NO 解法:纯数学题,先构造函数f(x ...
- 分形的奥秘!分形着色器!shader 编程入门实战 ! Cocos Creator!
极致的数学之美! 什么是分形? "一个粗糙或零碎的几何形状,可以分成数个部分,且每一部分都(至少近似地)是整体缩小后的形状" 简单来说,分形(fractal)就像这个doge表情包 ...