一、首先按照以下几个点展开对集合的学习
#一:基本使用
1 、用途
2 、定义方式
3 、常用操作+内置的方法
#二:该类型总结
1、 存一个值or存多个值 只能存一个值 可以存多个值,值都可以是什么类型
2 、有序or无序
3 、可变or不可变 !!!可变:值变,id不变。可变==不可hash !!!不可变:值变,id就变。不可变==可hash
二、集合
#作用:去重,关系运算,
# 知识点回顾 可变类型是不可hash类型 不可变类型是可hash类型
#定义集合:
集合:可以包含多个元素,用逗号分割,
集合的元素遵循三个原则:
1:每个元素必须是不可变类型(可hash,可作为字典的key)
2: 没有重复的元素
3:无序
注意集合的目的是将不同的值存放到一起,不同的集合间用来做关系运算,无需纠结于集合中单个值
#优先掌握的操作:
#1、长度len
#2、成员运算in和not in
#3、&交集
1 stus_linux={'alex','egon','张全蛋','李铁蛋','oldboy'}
2 stus_python={'李二丫','wxx','liudehua','alex','egon'}
3
4 #既报名linux又报名python的学生:交集
5 print(stus_linux & stus_python)
6 print(stus_linux.intersection(stus_python))
7
8 # 值都是 {'alex', 'egon'}
#4、|合集
1 stus_linux={'alex','egon','张全蛋','李铁蛋','oldboy'}
2 stus_python={'李二丫','wxx','liudehua','alex','egon'}
3
4 #所有的学生:并集
5 print(stus_linux | stus_python)
6 print(stus_linux.union(stus_python))
7
8 #值都是
9 #{'oldboy', 'egon', 'liudehua', '张全蛋', '李二丫', 'wxx', 'alex', '李铁蛋'}
#5、-差集
1 stus_linux={'alex','egon','张全蛋','李铁蛋','oldboy'}
2 stus_python={'李二丫','wxx','liudehua','alex','egon'}
3
4 #只报名linux,没有报名python的:差集
5 print(stus_linux - stus_python)
6 print(stus_linux.difference(stus_python))
7
8 #值为 {'oldboy', '李铁蛋', '张全蛋'}
9
10
11 #只报名python,没有报名linux的:差集
12 print(stus_python - stus_linux)
13 print(stus_python.difference(stus_linux))
14
15 #值为{'liudehua', '李二丫', 'wxx'}
#6、^对称差集
1 stus_linux={'alex','egon','张全蛋','李铁蛋','oldboy'}
2 stus_python={'李二丫','wxx','liudehua','alex','egon'}
3
4 # 没有同时报名两门课程的学生姓名:交叉补集
5 print(stus_linux ^ stus_python)
6 print(stus_linux.symmetric_difference(stus_python))
7
8
9 #值都为 {'李铁蛋', '李二丫', 'oldboy', 'liudehua', '张全蛋', 'wxx'}
#7、查看
1 s1={1,'a','b','c','d'}
2
3 for item in s1:
4 print(item)
5
6 #值的排序是随机的是上面五个元素的随机排序
#8、增加
1 s1={'a','b','c'}
2 s1.add('d') # 一次添加一个值
3 s1.add(4)
4 print(s1)
5
6 #值为{'a','b','c','d'}
7 s1.update({3,4,5}) #一次添加多个值
8 print(s1)
9
10 #值为{'a','b','c','d',3,4,5} 这里元素的顺序都是随机的
#9、删除
1 s1={'a','b','c'}
2 #s1.discard() ## 当删除的元素不存在的时候,不会报错
3 s1.discard(4)
4 print(s1) #值为{'a','b','c'}
5
6 #s1.remove() # 当删除的元素不存在的时候,报错
7 s1.remove(4) #报错
8
9 s1.pop() #随机取走一个元素
10 res=s1.pop()
11 print(res) #值是随机的
#10、父集,子集:
1 #父集:爹包含儿子
2 # s1={1,2,3}
3 # s2={1,2}
4 s1 > s2# 代表s1包含s2,s1是s2父集
5 s2 < s1 # s2是s1子集