一、字符編碼簡(jiǎn)史:
美國(guó):1963年 ASCII (包含127個(gè)字符 占1個(gè)字節(jié))
中國(guó):1980年 GB2312 (收錄7445個(gè)漢字,包括6763個(gè)漢字和682個(gè)其它符號(hào))
1993年 GB13000 (收錄20902個(gè)漢字)
1995年 GBK1.0 (收錄 21003個(gè)漢字)
2000年 GB18030 (收錄70244個(gè)漢字)
世界:1991年 unicode(‘萬(wàn)國(guó)碼'也就統(tǒng)一編碼,通常占2字節(jié),復(fù)雜的漢字占4字節(jié))
UTF-8 (可變長(zhǎng)的字符編碼)
二、python中的編碼解碼應(yīng)用
Python2中的字符串進(jìn)行字符編碼轉(zhuǎn)換過程是:
字節(jié)串-->decode('原來(lái)的字符編碼')-->Unicode字符串-->encode('新的字符編碼')-->字節(jié)串
#!/usr/bin/env python# -*- coding:utf-8 -*-utf_8_a = '測(cè)試'print(utf_8_a,type(utf_8_a),len(utf_8_a)) #打印utf_8_a的內(nèi)容、類型及長(zhǎng)度unicode_a = utf_8_a.decode('utf-8') #對(duì)utf_8_a進(jìn)行解碼成unicodeprint(unicode_a,type(unicode_a),len(unicode_a))gbk_a = utf_8_a.decode('utf-8').encode('gbk') #先解碼在編碼成gbkprint(gbk_a,type(gbk_a),len(gbk_a)) #打印gbk_a的內(nèi)存、類型及長(zhǎng)度print(gbk_a.decode('gbk'))----------------------------------------------------pytharm(python2.6)運(yùn)行結(jié)果:('/xe6/xb5/x8b/xe8/xaf/x95', <type 'str'>, 6)(u'/u6d4b/u8bd5', <type 'unicode'>, 2)('/xb2/xe2/xca/xd4', <type 'str'>, 4)測(cè)試Python3中定義的字符串默認(rèn)就是unicode,因此不需要先解碼,可以直接編碼成新的字符編碼:
字符串-->encode('新的字符編碼')-->字節(jié)串
#!/usr/bin/env python# -*- coding:utf-8 -*- utf_8_a = '測(cè)試'print(utf_8_a,type(utf_8_a),len(utf_8_a)) #打印utf_8_a的內(nèi)容、類型及長(zhǎng)度gbk_a = utf_8_a.encode('gbk')print(gbk_a.decode('gbk'),type(gbk_a),len(gbk_a)) --------------------------------------------------------pycharm(python3.6)運(yùn)行結(jié)果:測(cè)試 <class 'str'> 2測(cè)試 <class 'bytes'> 4以上這篇基于python 字符編碼的理解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選