copy和编码

对于赋值运算来说指向同一个内存地址.字典,列表,集合都一样

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。

 

posted @ 2018-03-26 15:32  徐阳阳  阅读(162)  评论(0编辑  收藏  举报