一、深浅拷贝
1. 值拷贝 ls1 = ls2 不开辟空间,指针跟着走。(直接将ls1中存放的地址拿过来,内存中不会开辟新的空间,所以你怎么变,我也跟着变。)(ls1内部的所有类型的值发生改变,ls2都会随之变化)
2. 浅拷贝 ls3 = ls1.copy() ls3新开辟空间,但数据内里面每个元素的地址同ls1。所以ls1中不可变类型变了,相当于ls1重新指到了一个新的地址,ls3还指向原来的那个地址。如果s1中可变类型的值变了,因为地址没变,只是值变了。所以ls3中可变类型的值也会一起变。(ls1内部的可变类型值发生改变,ls3会随之变化)
3. 深copy :ls4 = deepcopy(ls1) ls4中所有的数据都会重新开辟一个全新的空间,由于有优化机制,所以不可变类型会指向同一个地址。又由于不可
变类型值变了,地址一定会变,所以 deepcopy从内致外都不会受s1的影响,你怎么变跟我没关系。(ls1内部的所有类型的值发生改变,ls4都不会随之变化)
值拷贝:应用场景最多
ls = [1, 'abc', [10]]
ls1 = ls # ls1直接将ls中存放的地址拿过来
ls内部的值发生任何变化,ls1都会随之变化
ls2 = ls.copy() # 新开辟列表空间,但列表中的地址都是直接从ls列表中拿来
ls内部的可变类型值发生改变,ls2会随之变化
ls3 = deepcopy(ls) # 新开辟列表空间,ls列表中的不可变类型的地址直接拿过来,但是可变类型的地址一定重新开辟空间
ls内部的所有类型的值发生改变,ls3都不会随之变化
二、数据用法: 元组、字典、集合set
元组: 可理解为不可变列表
1.值可以为任意类型
2. 可以存放多个值------可以进行成员运算
3. 可以存放重复的值 - 可以计算成员出现的次数
4. 有序存储 - 可以通过索引取值,可以切片
常用操作:1. 索引取值,正反取:print(t1[1], print(t1[-3])
2. 运算(拼接),print((1, 2) + (2, 3))
3. 长度 len(t1)
4. 切片 print((2, 1, 3)[::-1])
5. 成员运算 print(True in t1); print(False in t1) # False == 0, t1中如果有0或False,该结果都是True
6. for循环 for obj in t1: print(obj, end=" ")
方法: count : print(t1.count(0)) # 对象0在元组中出现的次数;
index: print(t1.index(123, 4, len(t1))) # 对象123在区间4~末尾第一次出现的索引
字典相关 概念 :容器(集合):存放多个值的变量
单列容器(系统中的单列容器很多):list | tuple
双列容器(map):只有dict,存放数据 成对出现,dict存放数据采用 key-value键值对方式
字典中的key必须为不可变类型,因为key是取value的唯一依据,key一旦被确定,就不能被改变,所以只能是不可变类型
字典中的value可以为任意类型,value是用来存放世间所有存在的数据
key要确保唯一性,不能重复,值可以重复,并且可以被改变以此推到 => 字典为可变类型
dic = {'a': 10, 1: 20, True: 30, (): 40} # 1和True都是1,key具有唯一性,所以只保留最后一次值
print(dic) # {'a': 10, 1: 30, (): 40}
字典的定义:1.空字典{}、2.用map映射创建字典d3 = dict({'a': 1, 'b': 1})、
3.用关键字赋值方式:d4 = dict(name='Bob', age=18) # 参数=左侧的名字就是合法的变量名,都会被转化为字符串形式的key
4. 创建有多个key值采用默认值的方式: 默认值不写默认None,也可以自定义value:d5 = {}.fromkeys('abc', 0)---返回一个新字典。
字典的操作 增/改: 字典名[key] = 值 => key已存在就是修改值,不存在就是新增值:dic['c'] = 3
查:字典名[key]:只能查找已有的key,没有崩溃,
引入 dict.get(key, default =None) key -- 字典中要查找的键 default -- 如果指定键的值不存在时,返回该默认值.
清空 dic.clear()
pop(k):删除指定key的value并返还删除的value :res = dic.pop('a')
从dic末尾删除,返还(key, value)形成的元组: res = dic.popitem()
其他方法: 1.更新 dic.update(d) 原字典中,有相同的键,value就以新的 覆盖,没有键,就新增进去,原字典中多出来的就保留。----将一个字典添加到另一字典中
2.带默认值的新增 dic.setdefault('z', 100): 新增key,key已有,啥事不干,没有添加key,及value
3.字典的循环: for 得到key
4. 循环keys 效用等同for: for k in dic.keys()
5. 循环values : for v in dic.values()
6. 同时循环key和value 得到(key, value) : for res in dic.items()
7. 重点:for k, v in dic.items() 得到key, value 等同解压赋值
集合类型 空集合:不能用{},因为用来标示空字典,表示形式 :s = set()
定义:1.set为可变类型 - 可增可删 2. set自带去重存储 - set中不能存放重复数据
3. set为无序存储 - 不能索引取值
4. set为单列容器 - 没有取值的key-----不能取值
方法:1.增 s.add('1')
2. s.update({'2', '3'}) ,有就什么都不干,没有就新增
3. 合集:两个的合体 | print(py | Lx) 、 print(py.union(lx))
4. 对称交集 抛出共有的合体 ^ : print(py ^ lx)、print(py.symmetric_difference(lx))
5. 差集:独有的 print(py.difference(lx))----相当于减法
6. 比较 :前提一定是包含关系:s1 = {'1', '2'} ; s2 = {'2'} ;print(s1 < s2)