对于赋值运算来说指向同一个内存地址.字典,列表,集合都一样
copy:不是指向一个,在内存中开辟了一个内存空间 对于浅copy来说,第一层创建的是新的内存地址,
从第二层开始,指向的是同一个内存地址。 所以,对于第二层以及更深的层数来说,保持一致性。
l1 = [1,2,3] l2 = l1.copy() l1.append(111) ---> l2 = [1,2,3] l1 = [1,2,3,111]
但是: l1 = [1,2,[1,2],3] l2 = l1.copy() l1[2].append(666) -->l2和l1一样
#l2 = l1[:] --->切片都是浅copy
深copy :deep.copy import copy l1 = [1,2,[1,2],3] l2 = copy.deepcopy(l1) l1[2].append(666) -->l1和l2不同
编码 1.编码之间的二进制互不识别 2.存储和传输 010101...但是不能是unicode的010101...
数据类型: int bool
str byte与str方法相同
list dict
python3x 中的编码: python3X中str在内存中编码方式是unicode。不能直接存储和发送
byte的编码方式是非unicode(utf-8,gbk,...)
转化:encode编码:str-->bytes s = 'alex' s1 = s.encode('utf-8')
编码补充: str unicode
str-->bytes s1 = s.encode('gbk') s1 = s.encode('utf-8') 编码 Unicode->utf-8;unicode->gbk
bytes-->str s1 = s.decode('gbk') s1 = s.decode('utf-8') 解码 gbk->unicode;utf-8->unicode
gbk-->utf-8: 先将gbk 转化成unicode 再将Unicode转化成utf-8。