Python基础篇(set集合)
Python基础篇(set集合,深浅拷贝)
set集合是Python的一个基本类型,一般是不常用.set中的元素是不重复的.无序的里边
的元素必须是可hash的比如int,str,tuple,bool 我们可以这样记,set就是dict类型的数据但是不保存value,只保存key,
set也用{}表示
注意:set集合中的元素必须是可hash的,但是set本事是不可hash的. set是可变的.
- set1 = {'','alex',2,True,[1,2,3]} # 报错
- set2 = {'','alex',2,True,{1:2}} # 报错
- set3 = {'','alex',2,True,(1,2,[2,3,4])} # 报错
set中的元素是不重复的且是无序的.
- s = {"周杰伦", "周杰伦", "周星星"}
- print(s)
- 结果:
- {'周星星', '周杰伦'}
使用这个特性.我们可以使用set来去掉重复的
- # 给list去重复
- lst = [45, 5, "哈哈", 45, '哈哈', 50]
- lst = list(set(lst)) # 把list转换成set, 然后再转换回list
- print(lst)
set集合增删改查
1,增加
- s = {"刘嘉玲", '关之琳', "王祖贤"}
- s.add("郑裕玲")
- print(s)
- s.add("郑裕玲") # 重复的内容不会被添加到set集合中
- print(s)
- s = {"刘嘉玲", '关之琳', "王祖贤"}
- s.update("麻花藤") # 迭代更新
- print(s)
- s.update(["张曼玉", "李若彤","李若彤"])
- print(s)
2.删除
- s = {"刘嘉玲", '关之琳', "王祖贤","张曼⽟", "李若彤"}
- item = s.pop() # 随机弹出一个.
- print(s)
- print(item)
- s.remove("关之琳") # 直接删除元素
- # s.remove("马虎疼") # 不存在这个元素. 删除会报错
- print(s)
- s.clear() # 清空set集合.需要注意的是set集合如果是空的. 打印出来是set() 因为要和
- dict区分的.
- print(s) # set()
3.修改
- # set集合中的数据没有索引. 也没有办法去定位⼀个元素. 所以没有办法进行直接修改.
- # 我们可以采用先删除后添加的方式来完成修改操作
- s = {"刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}
- # 把刘嘉玲改成赵本⼭
- s.remove("刘嘉玲")
- s.add("赵本山")
- print(s)
4.查询
- # set是一个可迭代对象. 所以可以进行for循环
- for el in s:
- print(el)
5.常用操作
- s1 = {"刘能", "赵四", "皮长山"}
- s2 = {"刘科长", "冯乡长", "皮长山"}
- # 交集
- # 两个集合中的共有元素
- print(s1 & s2) # {'皮长山'}
- print(s1.intersection(s2)) # {'皮长山'}
- #并集
- print(s1 | s2) # {'刘科长', '冯乡长', '赵四', '皮长山', '刘能'}
- print(s1.union(s2)) # {'刘科长', '冯乡长', '赵四', '皮长山', '刘能'}
- # 差集
- print(s1 - s2) # {'赵四', '刘能'} 得到第⼀个中单独存在的
- print(s1.difference(s2)) # {'赵四', '刘能'}
- # 反交集
- print(s1 ^ s2) # 两个集合中单独存在的数据 {'冯乡长', '刘能', '刘科长', '赵四'}
- print(s1.symmetric_difference(s2)) # {'冯乡长', '刘能', '刘科长', '赵四'}
- s1 = {"刘能", "赵四"}
- s2 = {"刘能", "赵四", "皮长山"}
- # ⼦集
- print(s1 < s2) # set1是set2的⼦集吗? True
- print(s1.issubset(s2))
- # 超集
- print(s1 > s2) # set1是set2的超集吗? False
- print(s1.issuperset(s2))
set结合本省是可以发生改变的,是不可hash的我们可以用frozenset来保存数据.jrozenset是不可改变的
也是一个可哈希的数据类型.
- s = frozenset(["赵本⼭", "刘能", "皮长山", "长跪"])
- dic = {s:''} # 可以正常使用了
- print(dic)
这不是常用的
二.深浅拷贝
- lst1 = ["金毛狮王", "紫衫龙王", "白眉鹰王", "青翼蝠王"]
- lst2 = lst1
- print(lst1)
- print(lst2)
- lst1.append("杨逍")
- print(lst1)
- print(lst2)
- 结果:
- ['金毛狮王', '紫衫龙王', '白眉鹰王', '青翼蝠王', '杨逍']
- ['金毛狮王', '紫衫龙王', '白眉鹰王', '青翼蝠王', '杨逍']
- dic1 = {"id": 123, "name": "谢逊"}
- dic2 = dic1
- print(dic1)
- print(dic2)
- dic1['name'] = "范瑶"
- print(dic1)
- print(dic2)
- 结果:
- {'id': 123, 'name': '谢逊'}
- {'id': 123, 'name': '谢逊'}
- {'id': 123, 'name': '范瑶'}
- {'id': 123, 'name': '范瑶'}
对于list,set,di ct来说,直接赋值,其实是把内存地址交给了变量,并不是复制一份内容,所以
lst1的内存指向和lst2是一样的.lst1改变了,lst2也发生了改变
浅拷贝:
- lst1 = ["何炅", "杜海涛","周渝⺠"]
- lst2 = lst1.copy()
- lst1.append("李嘉诚")
- print(lst1)
- print(lst2)
- print(id(lst1), id(lst2))
- 结果:
- 两个lst完全不⼀样. 内存地址和内容也不⼀样. 发现实现了内存的拷⻉
- lst1 = ["何炅", "杜海涛","周渝⺠", ["麻花藤", "⻢芸", "周笔畅"]]
- lst2 = lst1.copy()
- lst1[3].append("⽆敌是多磨寂寞")
- print(lst1)
- print(lst2)
- print(id(lst1[3]), id(lst2[3]))
- 结果:
- ['何炅', '杜海涛', '周渝⺠', ['麻花藤', '马芸', '周笔畅', '⽆敌是多磨寂寞']]
- ['何炅', '杜海涛', '周渝⺠', ['麻花藤', '马芸', '周笔畅', '⽆敌是多磨寂寞']]
4417248328 4417248328
浅拷贝只会拷贝第一层,第二层的内容不会拷贝,所以被称为浅拷贝
深拷贝:
- import copy
- lst1 = ["何炅", "杜海涛","周渝⺠", ["麻花藤", "马芸", "周笔畅"]]
- lst2 = copy.deepcopy(lst1)
- lst1[3].append("⽆敌是多磨寂寞")
- print(lst1)
- print(lst2)
- print(id(lst1[3]), id(lst2[3]))
- 结果:
- ['何炅', '杜海涛', '周渝⺠', ['麻花藤', '马芸', '周笔畅', '⽆敌是多磨寂寞']]
- ['何炅', '杜海涛', '周渝⺠', ['麻花藤', '马芸', '周笔畅']]
- 4447221448 4447233800
都不一样了 ,深度拷贝,把元素完全进行拷贝赋值,不会产生一个改变另一个跟着改变的问题
Python基础篇(set集合)的更多相关文章
- python基础篇 07set集合 深浅拷贝
本节主要内容:1. 基础数据类型补充2. set集合3. 深浅拷⻉ " ".join方法 循环删除列表中的内容: 错误的 原因:在for循环中,循环到第一个,然后删除,删除之 ...
- python基础篇-day1
python基础篇 python是由C语言写的: pass 占位符: del,python中全局的功能,删除内存中的数据: 变量赋值的方法: user,pass = 'freddy','freddy1 ...
- 『Python基础-11』集合 (set)
# 『Python基础-11』集合 (set) 目录: 集合的基本知识 集合的创建 访问集合里的值 向集合set增加元素 移除集合中的元素 集合set的运算 1. 集合的基本知识 集合(set)是一个 ...
- python基础篇之进阶
python基础篇之进阶 参考博客:http://www.cnblogs.com/wupeiqi/articles/5115190.html python种类 1. cpython 使用c解释器生产 ...
- python基础篇(六)
PYTHON基础篇(六) 正则模块re A:正则表达式和re模块案例 B:re模块的内置方法 时间模块time A:时间模块的三种表示方式 B:时间模块的相互转换 随机数模块random A:随机数模 ...
- python基础篇(一)
PYTHON基础篇(一) 变量 赋值 输入,输出和导入 A:输入 B:输出 C:导入 运算符 A:算数运算符 B:比较运算符 C:赋值运算符 D:位运算符 E:逻辑运算符 F:成员运算符 G:身份运算 ...
- python基础篇(三)
PYTHON基础篇(三) 装饰器 A:初识装饰器 B:装饰器的原则 C:装饰器语法糖 D:装饰带参数函数的装饰器 E:装饰器的固定模式 装饰器的进阶 A:装饰器的wraps方法 B:带参数的装饰器 C ...
- python基础篇(四)
PYTHON基础篇(四) 内置函数 A:基础数据相关(38) B:作用域相关(2) C:迭代器,生成器相关(3) D:反射相关(4) E:面向对象相关(9) F:其他(12) 匿名函数 A:匿名函数基 ...
- 面试题之第一部分(Python基础篇) 80题
第一部分(python基础篇)80题 为什么学习Python?==*== # 1. python应用于很多领域,比如后端,前端,爬虫,机器学习(人工智能)等方面,几乎能涵盖各个开发语言的领域,同时它相 ...
随机推荐
- Linux修改密码指令
1.在选择系统菜单界面,按 "e" 进入编辑模式 2.在以字符串“Linux16”开头的行,将光标移动到该行的结尾,然后输入“init=/bin/bash”,按 "Ctr ...
- 灰常牛逼的命令行备忘录 navi
灰常牛逼的命令行备忘录 navi 1. navi命令简介 1.1 navi命令简介 命令行是非常高效的工具,但一个很常见的现象是,很多命令行过一段时间就容易忘.举个栗子,如果我们常用 git 命令行管 ...
- c语言开发浏览器插件
c语言开发浏览器插件 senk????sec???
- Sass-@each
@each 循环就是去遍历一个列表,然后从列表中取出对应的值. @each 循环指令的形式: @each $var in <list> 如果你没有接触过列表,也不要紧,他也非常简单. 在下 ...
- golang-练习2
反转字符串 package main import "fmt" func FirstReverse(str string) string { var str1 []rune run ...
- python基础:5.请编写一个函数实现将IP地址转换成一个整数。
如 10.3.9.12 转换规则为: 10 00001010 3 00000011 9 ...
- Graphics 绘图
Graphics类提供基本绘图方法,Graphics2D类提供更强大的绘图能力. Graphics类提供基本的几何图形绘制方法,主要有:画线段.画矩形.画圆.画带颜色的图形.画椭圆.画圆弧.画多边形等 ...
- k8s和docker区别
简要介绍: docker是一个开源的应用容器引擎,开发者可以打包他们的应用以及依赖到一个容器中,发布到流行的liunx系统上,或者实现虚拟化. k8s是一个开源的容器集群管理系统,可以实现容器集群的自 ...
- C# 创建日志
public void Log(string message) { try { string logFileName = "c:\\log\\LogName" + DateTime ...
- JS中关于引用类型数据及函数的参数传递
(JavaScript 中,函数的参数传递方式都是按值传递,没有按引用传递的参数) 一.数据类型 在 javascript 中数据类型可以分为两类: 基本类型值 primitive type,比如Un ...