转:代码老兵:http://blog.51cto.com/daimalaobing/2046659
编码:
最开始电脑的字符集是ASCII,英文在ASCII中每个字母占1个字节,但ASCII不支持中文,所以后来出现了Unicode;
Unicode中 英文和中文都占用两个字节,对于英文来说不合理,所以在Unicode的基础上出现了Unicode的扩展集UTF8;
UTF8中,英文如同ASCII一样,每个字母只占了1个字节,而每个中文占了3个字节;
目前中国Windows系统默认都是使用GBK字符集,如果一个软件使用的是GBK来开发的话,放到其他国家的电脑系统中,软件中的中文就会以乱码显示,因为其他国家电脑默认是不支持BGK的;
Unicode这个字符集所有国家电脑系统都支持,所以当想要把通过GBK开发的软件的中文,能在其他国家电脑中正常你显示就需要先将GBK转成Unicode,然后其他国家电脑系统可以用Unicode转成他们支持的字符集,反之亦然。
image_1c0ahauif1lmg115k1fmv8ik1r4q9.png-78.3kB如图:一个编码想转成另一个编码,必须先decode成Unicode,然后在encode成其他编码。
import sys
print (sys.getdefaultencoding()) #打印系统默认编码
image_1c0ahbpft1sq7tap19co9hajqm.png-0.8kB
在python3中,默认是utf-8(utf-8属于unicode的扩展集)
python2编码
import sys
print (sys.getdefaultencoding())
image_1c0ahe0kj199s1hd2p8hidd4h413.png-0.8kB
在python2中,默认是ascii
image_1c0ahee8t1u0c91n1nev181l1m1t1g.png-15.2kB image_1c0ahelvbmlt1mhj4qe1msb18rm1t.png-19kB在python2中,设置编码为utf-8;
写一个变量,这个变量会因为设置的原因,现在是utf-8
我们直接将这个变量(utf-8)进行转码到gbk,但是可以看到转码错误;正常转码之前,应该先解码成Unicode,但是我们这里没有做解码的操作,不过这里会自动做一个解码的操作,但这个自动解码的操作使用的是系统默认的ascii来解码,可我们的变量是utf-8,所以这里报错解码失败。
b = a.decode('utf-8') #这里指定源编码是utf-8,以utf-8为源编码转成unicode
image_1c0ahfpah1u3j107jp9iinm15ca2n.png-3.6kB
这里我们先做一个解码操作,打印之后,我们可以看到打印type(b)可以正常显示是unicode,而打印的b却不正常,这是因为可以看到打印出来的是元组,unicode编码在元组中不会显示中文,只会以编码形的格式显示,在格式的前面有一个u,表示unicode;
print (b) #需要单独打印b,才不会以元组的形式打印
image_1c0ahgnm0m26u8n1c4p1m8di4p34.png-0.4kB
c = b.encode('gbk') #将unicode转成gbk
print (c)
image_1c0ahhbo18mptsc1thb1rua1jnj3h.png-0.7kB
打印出来的是乱码,这是当前pycharm调整了编码模式为utf-8,所以打印gbk出来时是乱码
image_1c0ahhnvv1n4ul2a1c3toak1ul53u.png-73.7kB把pycharm改成GBK咋打印gbk就不是乱码了
image_1c0ahi25e73e100e1oel1c9e1sv44b.png-8.8kBc = b.encode('gbk') #从unicode转成gbk
image_1c0ahimgh7ug19sqrqq18m71g4h4o.png-5kB
已经看到打印gbk不是乱码了,同时打印b(unicode)也同样不是乱码,这是因为unicode可以兼容所有编码,所以不会是乱码,如果这里是assic就会是乱码了
f = c.decode('gbk').encode('utf-8') #将当前的gbk解码为unicode,然后在编码为utf-8
print (f)
image_1c0ahj91b132o118o1pnb1pg5std55.png-0.5kB
打印出来是乱码
image_1c0ahjmju1303eohbejsn9q965i.png-55.2kB image_1c0ahk7bc1a1ehukiebintuo25v.png-5.5kB可以看到最后打印utf-8的已经不是乱码了; 不过在之上的gbk就成乱码了。
x = u'一二三' #在'一二三'前面有个u,表示直接转码为unicode
print (x)
image_1c0ahl5421f866n46fphj417gs6s.png-0.3kB
可以看到unicode在utf-8编码下也能正常显示。
y = x.encode('gbk') #unicode编码可以直接encode为其他编码
print (y)
python3编码
import sys
print (sys.getdefaultencoding())
#python3默认就属于unicode,utf-8属于unicode的扩展集,所以也算是unicode
a = '哈喽'
print (a.encode('gbk')) #unicode可以直接转成其他编码
image_1c0ahmq861ifeo568n11oti1kk179.png-2.6kB
转成编码后因为当前pycharm是unicode,所以没有正常显示。
前面有个b,表示被转成bytes类型
在pycharm的右下角可以直接转换编码为gbk,这里只是将文件编码转为gbk和程序的编码无关
image_1c0ahnlu4nne4l71huv9r01a5a83.png-18.9kB再去执行的时候,发现报错,这是因为之前写代码的时候默认是unicode,现在已经转换成gbk了,但是代码还是根据默认unicode来写的;
image_1c0aho9db13vpri1jknli2l9h8g.png-11.8kB所以要在文件开头进行声明,文件编码是gbk,注意这里只是声明文件编码是gbk和程序编码无关;
目前python3程序默认还是unicode
目前a = '哈喽'还是属于unicode(因为python3默认是unicode)
image_1c0ahp6c81hfi18mk9cd1nb11tjf9a.png-24.2kB可以看到因为当前a属于unicode,所以不能做decode操作(图中没有decode可选)
image_1c0ahphbh1tpl4m6u8mloc1k3n9n.png-12.1kB从unicode转成gbk
image_1c0ahpq373s11vdqb4tnq414rta4.png-2.2kB
当前是bytes类型的数据,所以无法显示字符串
image_1c0ahqbgtrq41q61bfn1k4o1132ah.png-17.1kB image_1c0ahqgie1gcd4a61haj1hmn1dooau.png-4.4kB注意在python3中,encode后不光转了编码,还将数据编程bytes类型
image_1c0ahqu346u28r4154qhil1pelbb.png-15.1kB image_1c0ahr4l318h615fb804nn1m7gbo.png-4kBdecode一下就可以显示中文字符串了。
windows默认是gbk
linux默认是utf-8
python2默认是ascii
python3默认是unicode
最终要记住的就是,无论在python2还是在python3上,要做的是确认当前使用的编码集,任何非unicode编码集都要decode成unicode,然后通过unicode在encode成想要的编码集;
如果当前直接就是unicode,可以直接encode想要的编码集。
在python3上默认是unicode,中文和英文都按照两个字节存储,通过声明 # -*- coding:utf -8-*-
,编码就为utf-8了,这样英文存储为1个字节,中文为3个字节。
网友评论