集合set以及深浅copy
集合set:无序,不重复。虽然属于可变的数据类型,但里面的元素必须是不可变的数据类型
set1=set{1,2,3,"str"}
set1 = set({1,2,3})
set2 = {1,2,3,[2,3],{'name':'alex'}} # 错的
print(set1)
print(set2)
set1 = {'alex','wusir','ritian','egon','barry',}
关于可变与不可变数据类型分类:
- 可变数据类型(不可哈希):列表(list),字典(dict),集合(set)
- 不可变数据类型(可哈希):元组(tuple),int,str,bool
集合的增删改查:
增加:
add
set1.add('女神')
update
set1 = set({1,2,3,"str"})
set2={'a','b','c'}
set2.update(set1)
print(set2)
删除:
set1.pop() # 随机删除 print(set1.pop()) # 有返回值 print(set1) set1.remove('alex') # 按元素 print(set1) {} set() set1.clear() print(set1) # set() del set1 print(set1)
查询:
for i in set1: print(i)
求交集、并集、子集
交集:
set1 = {1,2,3,4,5}
set2 = {4,5,6,7,8}
set3 = set1 & set2
print(set3) # {4, 5} 求交集
print(set1.intersection(set2)) # {4, 5} 求交集
并集:
set1 = {1,2,3,4,5}
set2 = {4,5,6,7,8}
print(set1 | set2) # {1, 2, 3, 4, 5, 6, 7,8} 求并集
print(set2.union(set1)) # {1, 2, 3, 4, 5, 6, 7} 求并集
求交集的反集:
set1 = {1,2,3,4,5}
set2 = {4,5,6,7,8}
print(set1 ^ set2) # {1, 2, 3, 6, 7, 8} 求交集的反集
print(set1.symmetric_difference(set2)) # {1, 2, 3, 6, 7, 8} 求交集的反集
第一个集合减去第一个集合与另一个集合的交集
set1 = {1,2,3,4,5}
set2 = {4,5,6,7,8}
print(set1 - set2) # {1, 2, 3}
#set1独有的
print(set1.difference(set2)) # {1, 2, 3}
求证一个集合是否是另一个集合的子集或超集
set1 = {1,2,3,}
set2 = {1,2,3,4,5,6}
print(set1 < set2)
print(set1.issubset(set2)) # 这两个相同,都是说明set1是set2子集。
print(set2 > set1)
print(set2.issuperset(set1)) # 这两个相同,都是说明set2是set1超集。
去重
li = [1,2,33,33,2,1,4,5,6,6] set1 = set(li) # print(set1) li = list(set1) print(li) s1 = {1,2,3} print(s1,type(s1))
创建一个不可变的集合
s = frozenset('barry') print(s,type(s)) for i in s: print(i)
关于深浅copy
赋值运算
l1 = [1,2,3] l2 = l1 l1.append('a') print(l1,l2)
浅copy
l1 = [1,2,3] l2 = l1.copy() print(l1,l2) print(id(l1),id(l2)) l2.append('a') print(l1,l2)
l1 = [1,2,[4,5,6],3] l2 = l1.copy() print(l1,id(l1)) print(l2,id(l2)) l1.append('a') print(l1,l2) l1[2].append('a') print(l1,l2) print(id(l1[2])) print(id(l2[2]))
深度copy
暂无资料
循环打印
li = ['alex','taibai','wusir','egon'] 从0开始 for i in li: print(li.index(i),i) 或 for index,i in enumerate(li,1): 从1开始 print(index,i)

浙公网安备 33010602011771号