国产成人AV无码一二三区,少女1到100集,国产精品久久久久精品综合紧,巜公妇之诱感肉欲HD在线播放

文章 > Python高级 > 一文了解py2/py3编码问题

一文了解py2/py3编码问题

头像

爱喝马黛茶的安东尼

2019-10-30 14:08:052908浏览 · 0收藏 · 0评论

无论是py2还是py3,都使用unicode作为内存编码,简称内码。保存在python解释器内存中的文本,输出到屏幕、编辑器,或者保存成文件的时候,都要将内码转换成utf8或者gbk等编码格式;同样,python解释器从输入设备接收文本,或者从文件读取文本的时候,都要将utf8或者gbk等编码转换成unicode编码格式。

因此,无论是py2还是py3,想要在unicode、utf8、gbk等编码格式之间转换的话,下图是通用的:

我们之所以会产生困惑,是因为py2和py3给这些编码格式指定了令人困惑的名字。

py2的字符串有两种类型:unicode类型和str类型。

py2的unicode类型就是unicode编码,py2的str类型泛指除unicode编码之外的所有编码,包括ascii编码、utf8编码、gbk编码、cp936编码等。

py3的字符串也有两种类型:bytes类型和str类型。py3的str类型就是unicode编码,py3的bytes类型泛指除unicode编码之外的所有编码,包括ascii编码、utf8编码、gbk编码、cp936编码等。

同样是str类型,在py2和py3中完全颠倒了!下图稍微补充了一点内容,更有助于理解编码问题。

接下来,我们实战演练一下。

>>> s = 'abc天圆地方'
>>> type(s)
<class 'str'>
>>> len(s)
7
>>> s
'abc天圆地方'
>>> print(s)
abc天圆地方
>>> s.encode('unicode-escape')
b'abc\\u5929\\u5706\\u5730\\u65b9'

不管是否在字符串前面加了u,只要不在字符串前面使用b,在IDLE中定义的字符串都是unicode编码,也就是py3的<class ‘str’>,其长度就是字符数量,不是字节数。我们把unicode字符串’abc天圆地方’转成utf8编码:

>>> s_utf8 = s.encode('utf8')
>>> type(s_utf8)
<class 'bytes'>
>>> len(s_utf8)
15
>>> s_utf8
b'abc\xe5\xa4\xa9\xe5\x9c\x86\xe5\x9c\xb0\xe6\x96\xb9'
>>> print(s_utf8)
b'abc\xe5\xa4\xa9\xe5\x9c\x86\xe5\x9c\xb0\xe6\x96\xb9'
>>> s_utf8.decode('utf8')
'abc天圆地方'

utf8编码就是bytes类型(字节码),长度就是字节数量。我们把unicode字符串’abc天圆地方’转成gbk编码:

>>> s_gbk= s.encode('gbk')
>>> type(s_gbk)
<class 'bytes'>
>>> len(s_gbk)
11
>>> s_gbk
b'abc\xcc\xec\xd4\xb2\xb5\xd8\xb7\xbd'
>>> print(s_gbk)
b'abc\xcc\xec\xd4\xb2\xb5\xd8\xb7\xbd'
>>> s_gbk.decode('s_gbk')
'abc天圆地方'

gbk编码也是bytes类型(字节码),长度也是字节数量。我们再来看看,不同编码的字节码能否连接:

>>> ss = s_utf8 + s_gbk
>>> ss
b'abc\xe5\xa4\xa9\xe5\x9c\x86\xe5\x9c\xb0\xe6\x96\xb9abc\xcc\xec\xd4\xb2\xb5\xd8\xb7\xbd'
>>> ss.decode('utf8')
Traceback (most recent call last):
  File "<pyshell#64>", line 1, in <module>
    ss.decode('utf8')
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xcc in position 18: invalid continuation byte
>>> ss.decode('gbk')
'abc澶╁渾鍦版柟abc天圆地方'
>>> ss.decode('utf8', 'ignore')
'abc天圆地方abc??'
>>> ss.decode('gbk', 'ignore')
'abc澶╁渾鍦版柟abc天圆地方'

看以看出,不同编码的字节码可以连接,但一般不能解码成unicode(字符串),除非使用ignore参数。

python学习网,免费的在线学习python平台,欢迎关注!

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

《年轻朋友的妻子3》| 女性变态黄丝连体开档内衣| 林语惊| 一母四女共一婿的全诗解读| 金瓶第1回双乳被吸| 两个人轮流上24小时的班| 99精产国品一二三产区区别电影| 《漾出OVER FLOWER》…| 《我们不是亲兄妹》动浸播放| 干露露和干毛毛的身材对比照片 | 乱公伦媳..HH| 《瞒着丈夫说在公司加班》中字| 小辣椒3美国伦理| 舌头伸进去添的我爽高潮| 陌陌影视在线观看高清完整版 | 《一滴都不许漏》何泽城林荫| 老公把闺蜜干的嗷嗷叫| 《列车上的轮杆》1-4 | 《帐篷里的秘密》动漫| 《囚禁空姐》电影免费观看| 《请好好疼爱里面》免费观看| 法国内衣秀| 我的小后妈中字ID| 星空传媒天美传媒有限公司| 男女啪啪做爰高潮全过有多动症| BOBO浏览器(海外版)| 妈妈がだけの母さん歌词| 妈妈说今晚爸爸不回家| 引诱亲女乱第24部分阅读| 坤坤寒入桃子里电视剧免费看 | 男生女生一起愁愁愁电视剧在线观.| 《卻望1973》娃娃脸| 《警花交换做爰》| 年轻的保姆| 偷偷在线观看免费高清电视剧推荐| 姐姐用脚帮你打枪| 亲吻哼哼唧唧原声不带歌| 国产 欧美一区二区三区| 麻花传剧MV无痕免费观看姐弟 | 《交换温柔》免费观看全集完整版| 《一滴都不许漏》何泽城林荫