set集合
set集合是python的一个基本数据类型. 一般不是很常用. set中的元素是不重复的.无序的.
里面的元素必须是可hash的(int, str, tuple,bool), 我们可以这样来记. set就是dict类型的数据但是不保存value, 只保存key. set也用{}表示
注意: set集合中的元素必须是可hash的, 但是set本身是不可hash得. set是可变的.
set1 = { '1','alex',2,True,[1,2,3]} # 报错set2 = { '1','alex',2,True,{1:2}} # 报错set3 = { '1','alex',2,True,(1,2,[2,3,4])} # 报错
set主要用于去重复
set集合增删改查
增加
s = { "刘嘉玲", '关之琳', "王祖贤"}s.add("郑裕玲")print(s) # {'王祖贤', '郑裕玲', '刘嘉玲', '关之琳'}s.add("郑裕玲") # 重复的内容不会被添加到set集合中print(s) # {'王祖贤', '郑裕玲', '刘嘉玲', '关之琳'}s = { "刘嘉玲", '关之琳', "王祖贤"}s.update("麻花藤") # 迭代更新print(s) # {'麻', '刘嘉玲', '花', '王祖贤', '藤', '关之琳'}s.update(["张曼⽟", "李若彤","李若彤"])print(s) # {'麻', '刘嘉玲', '花', '王祖贤', '藤', '关之琳'}
删除
s = { "刘嘉玲", '关之琳', "王祖贤","张曼⽟", "李若彤"}item = s.pop() # 随机弹出⼀个.print(s) # {'张曼⽟', '王祖贤', '刘嘉玲', '关之琳'}print(item) # 李若彤s.remove("关之琳") # 直接删除元素# s.remove("麻花藤") # 不存在这个元素. 删除会报错print(s) # {'张曼⽟', '王祖贤', '刘嘉玲'}s.clear() # 清空set集合.需要注意的是set集合如果是空的. 打印出来是set() 因为要和dict区分的.print(s) # set()
修改
# set集合中的数据没有索引. 也没有办法去定位一个元素. 所以没有办法进行直接修改. # 我们可以采用先删除后添加的⽅式来完成修改操作s = { "刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}# 把刘嘉玲改成赵本山s.remove("刘嘉玲")s.add("赵本山")print(s)
查找
# set是一个可迭代对象. 所以可以进行for循环s = { "刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}for el in s: print(el)
常用操作
交集
s1 = { "刘能", "赵四", "皮长山"}s2 = { "刘科长", "冯乡长", "皮长山"}print(s1 & s2) # {'皮长山'}print(s1.intersection(s2)) # {'皮长山'}
并集
s1 = { "刘能", "赵四", "皮长山"}s2 = { "刘科长", "冯乡长", "皮长山"}print(s1 | s2) # {'刘科长', '冯乡长', '赵四', '皮长山', '刘能'}print(s1.union(s2)) # {'刘科长', '冯乡长', '赵四', '皮长山', '刘能'}
差集
s1 = { "刘能", "赵四", "皮长山"}s2 = { "刘科长", "冯乡长", "皮长山"}print(s1 - s2) # {'赵四', '刘能'} 得到第一个中单独存在的print(s1.difference(s2)) # {'赵四', '刘能'}
反交集
s1 = { "刘能", "赵四", "皮长山"}s2 = { "刘科长", "冯乡长", "皮长山"}print(s1 ^ s2) # 两个集合中单独存在的数据 {'冯乡长', '刘能', '刘科长', '赵四'}print(s1.symmetric_difference(s2)) # {'冯乡长', '刘能', '刘科长', '赵四'}
子集
s1 = { "刘能", "赵四"}s2 = { "刘能", "赵四", "皮长山"}print(s1 < s2) # set1是set2的子集吗? Trueprint(s1.issubset(s2))
超集
s1 = { "刘能", "赵四"}s2 = { "刘能", "赵四", "皮长山"}print(s1 > s2) # set1是set2的超集吗? Falseprint(s1.issuperset(s2))