直接赋值、浅拷贝、深拷贝区别
直接赋值
例
list1 = [1,2,[1,2,3]]
list2 = list1.copy()
print(id(list1))
print(id(list2))
通过id 可以发现list1和list2 都指向同一个内存地址,所以更改其中一个 另一个也会相应改变
浅拷贝
list1 = [1,2,[1,2,3]]
list2 = list1.copy()
print(id(list1))
print(id(list2))
通过id可以发现 拷贝完成的list2 和原先的list1 有不同的id
list1[0]=100
list1[2][2]=100
print(list1)
print(list2)
可以发现list2的子对象会随着list1的改变而改变
list1 = [1,2,[1,2,3]]
list2 = list1.copy()
print(id(list1[2]))
print(id(list2[2]))
可以发现 子对象的id是一样的
总结:浅拷贝 完成后 列表有不同的id 但是 子对象的id是一样的
深拷贝
list1 = [1,2,[1,2,3]]
list2 = list1.deepcopy()
print(id(list1))
print(id(list2))
与浅拷贝一样 list1和list2有不同的id
list1 = [1,2,[1,2,3]]
list2 = list1.deepcopy()
print(id(list1[2]))
print(id(list2[2]))
子对象id不同
总结:深拷贝会创建和原来完全不同的列表,他们的列表对象和子对象是完全独立的,操作也是独立的。
排序
sort方法
用法
list1.sort()
def sort(self, *args, **kwargs): # real signature unknown
""" Stable sort *IN PLACE*. """
pass
该方法没有返回值,但是会对列表的对象进行排序。
参数
- key – 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
- reverse – 排序规则,reverse = True 降序, reverse = False 升序(默认)。
内置函数sorted
用法:
list1= [1,3,2,6,4,7,5]
list2 = sorted(list1)
sort 与 sorted 区别:
sort 是应用在 list 上的方法,sorted 可以对所有可迭代的对象进行排序操作。
list 的 sort 方法返回的是对已经存在的列表进行操作,而内建函数 sorted 方法返回的是一个新的 list,而不是在原来的基础上进行的操作。
reverse方法
用于列表
没返回值 所以在当前的数据上操作
不排序 只逆置
例:
list1 = [3,1,4,2,6,5]
print(list1.reverse())
reversed函数 迭代器
迭代器 :一边计算一边循环,保存算法 不保存数据
用于所有可迭代对象
有返回值 返回一个迭代器对象 要访问值用for循环
例:
list1 = [3,1,4,2,6,5]
ret = reversed(list1)
for i in ret:
print(i)