一、深浅拷贝
1.浅拷贝,只会拷贝第一层
s = [1, 'ss', '小可爱'] s1 = s.copy() print(s1)
>>>
[1, 'ss', '小可爱']
s = [1, 'ss', '小可爱'] s1 = s.copy() s1[0] = 3 #修改s1的值 print(s1)
>>>
[3, 'ss', '小可爱']
#浅拷贝,只会拷贝第一层,修改完s1里面列表的值后,数据源也会改变 s = [[1, 2], 'ss', '小可爱'] s1 = s.copy() s1[0][1] = 3 #修改s1的值 print(s1) print(s)
>>>
[[1, 3], 'ss', '小可爱']
[[1, 3], 'ss', '小可爱']
2.深拷贝 = 克隆一份
import copy s = [[1, 2], 'ss', '小可爱'] s1 = copy.deepcopy(s) s1[0][1] = 3 #修改s1的值 print(s) print(s1)
>>>
[[1, 2], 'ss', '小可爱'] [[1, 3], 'ss', '小可爱']
二、集合:
把不同的元素集合到一起,组成集合的成员不可重复如果有重复的元素保留一个
主要作用:
1.去重,把一个列表变成集合就自动去重了;
2.关系测试,交集、并集等关系
集合的创建:
a = set('xiaoss baby')
print(a) # 输出:{'a', 'y', 'b', 'o', 'x', ' ', 'i', 's'}
分类:可变集合、不可变集合
可变集合(set):可添加和删除元素,非可哈希的,不能做字典的键和其他集合的元素
不可变集合(frozenset):与上相反
基本操作:
li = ['xiao', 2, 5] s = set(li) s.add('baby') #添加一个元素 print(s) s.update('ops') # 把要添加的字符串作为一个单独的序列加到集合里 print(s)
>>>
{2, 'xiao', 'baby', 5} {2, 5, 'o', 'baby', 'p', 'xiao', 's'}
li = ['xiao', 2, 5] s = set(li) s.update('ooo') # 重复的字符只添加一个到集合里 print(s)
>>>
{'o', 2, 'xiao', 5}
li = ['xiao', 2, 5] s = set(li) s.update([12, 'baby']) # 添加多个元素要放到一个容器里 print(s)
>>>
{2, 5, 'baby', 12, 'xiao'}
#删除操作
li = ['xi', 2, 5] s = set(li) # 删除 s.remove(2) # ()里存放要删除的内容 s.pop() # 随机删除一个 s.clear() # 清空 del s # 直接删除整个集合 print(s)
>>>
print(set('qwer') == set('qwereq')) # True 因为两者形成的集合结果一样,所以等价 print(set('qwer') < set('qwerty')) #True < 表示后者包含前者
>>>
True True
# 联合操作 print(set('qwer') or set('qwerty')) # 取两者共同的 print(set('qwer') and set('qwerty')) # 取两者包含的所有序列元素
>>>
{'w', 'e', 'q', 'r'} {'w', 'y', 'r', 't', 'e', 'q'}
a = set([1, 2, 3, 4, 5]) b = set([3, 4, 5, 6, 7]) # intersection() 交集 print(a.intersection(b)) print(a & b) #同上 #union 并集 print(a.union(b)) print(a | b) #同上 # 差集(互相不在对方里面) print(a.difference(b)) # 在a不在b 或print(a - b) print(b.difference(a)) # 在b不在a 或print(b - a) # 反向交集 print(a.symmetric_difference(b)) # 父集 print(a.issuperset(b)) # 判断a是否完全包含于b # 子集 print(a.issubset(b))
>>>
{3, 4, 5} {3, 4, 5} {1, 2, 3, 4, 5, 6, 7} {1, 2, 3, 4, 5, 6, 7} {1, 2} {6, 7} {1, 2, 6, 7} False False