Python2内容默认ascii进行编码,而Python3对内容进行编码的默认为utf-8。这个编码问题,也不是Python的问题,所有语言都有乱码的问题,所以今天主要跟大家聊聊这4个常见的编码 。
主要有以下几个编码:
1、ASCII
ASCII码使用一个字节编码,所以它的范围基本是只有英文字母、数字和一些特殊符号 ,只有256个字符。
2、Unicode
俗称万国码,把所有的语言统一到一个编码里.解决了ascii码的限制以及乱码的问题。
unicode码一般是用两个字节表示一个字符,特别生僻的用四个字节表示一个字符。
3、UTF-8
新的问题出现了,如果统一成unicode编码,乱码问题从此消失了。但是如果你写的文本基本上都是英文的,用Unicode编码比ascii编码需要多一倍的存储空间,在存储和传输上十分不方便。
utf-8应用而生,它是一个"可变长的编码方式",如果是英文字符,则采用ascii编码,占用一个字节.如果是常用汉字,就占用三个字节,如果是生僻的字就占用4~6个字节.
4、GBK
GBK是只用来编码汉字的,GBK全称《汉字内码扩展规范》,使用双字节编码。
介绍完上面四种,下面贴上一张5种常见编码的对比,更直观的了解这几种编码的区别 。