码迷,mamicode.com
首页 > 编程语言 > 详细

python2 与python3中最大的区别(编码问题bytes&str

时间:2018-05-18 11:22:49      阅读:2308      评论:0      收藏:0      [点我收藏+]

标签:xtend   字节   lin   type   insert   class   abc   inux   图片   

 

1,在python2.x 中是不区分bytes和str类型的,在python3中bytes和str中是区分开的,str的所有操作bytes都支持

python2 中                                                    

>>> s = "abcdefg"
>>> b = s.encode()    #或者使用下面的方式

>>> b = b"abcdefg"
>>> type(b)
<type ‘str‘>


python3中     #str和bytes是严格区分的

>>> s = "abcdefg"
>>> type(s)
<class ‘str‘>
>>> b = b"abcdefg"
>>> type(b)
<class ‘bytes‘>


str是文本系列,bytes是字节系列

文本是有编码的(UTF-8,GBK,GB2312等)

字节没有编码

文本的编码指的是字符如何使用字节来表示组织方式,linux下默认都使用UTF-8



2,bytes与str之间的转换-------编码

bytes由str通过encode方法转化得到的,str也可以通过bytes 通过decode方法转化得到

通过b前缀可以定义bytes

GBK 是双字节,UTF-8 灵活编码,1字节,2字节,3字节,4字节都有,最大支持6字节长度,中文大多数是3字节


>>> S = "我是中国人"
>>> S
‘我是中国人‘
>>> b = S.encode()     #进行编码为bytes
>>> b
b‘\xe6\x88\x91\xe6\x98\xaf\xe4\xb8\xad\xe5\x9b\xbd\xe4\xba\xba‘
>>> b.decode()    #进行解码为字符串
‘我是中国人‘
>>>

str被编码成什么格式的,就需要使用什么格式的编码进行解码

>>> S = "我是中国人"
>>> S
‘我是中国人‘
>>> b = S.encode(‘GBK‘)
>>> b
b‘\xce\xd2\xca\xc7\xd6\xd0\xb9\xfa\xc8\xcb‘
>>> b.decode(‘GBK‘)
‘我是中国人‘


可以使用bin( )将一个10进制整数或者16进制数转化为2进制

>>> bin(10)
‘0b1010‘
>>>

>>> bin(0xce)
‘0b11001110‘


3,bytes的操作

bytes具有string类型的所有操作,bytes可以通过str encode转化,也可以通过前缀b定义

>>> b = b‘abc‘
>>> b
b‘abc‘
>>> b.decode()
‘abc‘


>>> b‘abc‘.find(b‘c‘)
2

>>> len((‘我是中国人‘).encode())      #求bytes的长度
15
>>> b
b‘abc‘
>>> b.hex()   #转化为16进制
‘616263‘

>>> bin(616263)      #转化为2进制
‘0b10010110011101000111‘


除了encode外,str操作都有对应的bytes版本,但是传入的参数必须是bytes


                                                                          
bytearray类型

bytearray是可变的,bytes和str是不可变的,主要用于图片处理

相对bytes来说,多了insert,append,extend,pop,remove,clear,reverse等操作,并且支持索引操作


>>> S1 = "人生苦短,我学python!"
>>> S1
‘人生苦短,我学python!‘
>>> b1 = bytearray(S1.encode())
>>> b1.decode()
‘人生苦短,我学python!‘

>>> b1
bytearray(b‘\xe4\xba\xba\xe7\x94\x9f\xe8\x8b\xa6\xe7\x9f\xad\xef\xbc\x8c\xe6\x88\x91\xe5\xad\xa6python\xef\xbc\x81‘)
>>> b1[:6] = bytearray(‘生命‘.encode())
>>> S1
‘人生苦短,我学python!‘
>>> b1
bytearray(b‘\xe7\x94\x9f\xe5\x91\xbd\xe8\x8b\xa6\xe7\x9f\xad\xef\xbc\x8c\xe6\x88\x91\xe5\xad\xa6python\xef\xbc\x81‘)
>>> b1.decode()
‘生命苦短,我学python!‘
>>>

 

原文:https://blog.csdn.net/u010694764/article/details/53811035

python2 与python3中最大的区别(编码问题bytes&str

标签:xtend   字节   lin   type   insert   class   abc   inux   图片   

原文地址:https://www.cnblogs.com/fmgao-technology/p/9054802.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!