在之前的学习中,遇到的copy都只是简单的浅拷贝,相对应得也有深拷贝
1.深浅拷贝
对象的拷贝
import copy
copy.copy: 浅拷贝,仅仅拷贝对象的第一层
copy.deepcopy: 深拷贝,会递归拷贝
浅拷贝:
深拷贝:
可以看到c能将123123也拷贝到,是一种递归拷贝,而b不行,这就是深拷贝。
2.生成器
列表推导式
i for i in range(101)
i for i in range(1,101) if i % 2 == 0
i*j for i in range(1,10) for j in range(1,10)
列表推导式很强大,但是直接生成列表,那么当列表中的元素特别多的时候,内存的占有很大
列表生成器
将列表推导式转化为列表生成器
将列表中的[]使用()来代替
获取其中的值:
for i in a:
if i ==10
print(i)
使用全局函数next,并且返回下一个值,不能后退,只能前进,直到最后报出异常
如果数据很多,将会很占内存,于是有了生成器对象