基于python 字符編碼的理解
一、字符編碼簡史:
美國:1963年 ASCII (包含127個字符 占1個字節(jié))
中國:1980年 GB2312 (收錄7445個漢字,包括6763個漢字和682個其它符號)
1993年 GB13000 (收錄20902個漢字)
1995年 GBK1.0 (收錄 21003個漢字)
2000年 GB18030 (收錄70244個漢字)
世界:1991年 unicode(‘萬國碼'也就統(tǒng)一編碼,通常占2字節(jié),復(fù)雜的漢字占4字節(jié))
UTF-8 (可變長的字符編碼)
二、python中的編碼解碼應(yīng)用
Python2中的字符串進(jìn)行字符編碼轉(zhuǎn)換過程是:
字節(jié)串-->decode('原來的字符編碼')-->Unicode字符串-->encode('新的字符編碼')-->字節(jié)串
#!/usr/bin/env python
# -*- coding:utf-8 -*-
utf_8_a = '測試'
print(utf_8_a,type(utf_8_a),len(utf_8_a)) #打印utf_8_a的內(nèi)容、類型及長度
unicode_a = utf_8_a.decode('utf-8') #對utf_8_a進(jìn)行解碼成unicode
print(unicode_a,type(unicode_a),len(unicode_a))
gbk_a = utf_8_a.decode('utf-8').encode('gbk') #先解碼在編碼成gbk
print(gbk_a,type(gbk_a),len(gbk_a)) #打印gbk_a的內(nèi)存、類型及長度
print(gbk_a.decode('gbk'))
----------------------------------------------------
pytharm(python2.6)運行結(jié)果:
('\xe6\xb5\x8b\xe8\xaf\x95', <type 'str'>, 6)
(u'\u6d4b\u8bd5', <type 'unicode'>, 2)
('\xb2\xe2\xca\xd4', <type 'str'>, 4)
測試
Python3中定義的字符串默認(rèn)就是unicode,因此不需要先解碼,可以直接編碼成新的字符編碼:
字符串-->encode('新的字符編碼')-->字節(jié)串
#!/usr/bin/env python
# -*- coding:utf-8 -*-
utf_8_a = '測試'
print(utf_8_a,type(utf_8_a),len(utf_8_a)) #打印utf_8_a的內(nèi)容、類型及長度
gbk_a = utf_8_a.encode('gbk')
print(gbk_a.decode('gbk'),type(gbk_a),len(gbk_a))
--------------------------------------------------------
pycharm(python3.6)運行結(jié)果:
測試 <class 'str'> 2
測試 <class 'bytes'> 4
以上這篇基于python 字符編碼的理解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決import tensorflow as tf 出錯的原因
這篇文章主要介紹了解決import tensorflow as tf 出錯的原因,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
Django 實現(xiàn)對已存在的model進(jìn)行更改
這篇文章主要介紹了Django 實現(xiàn)對已存在的model進(jìn)行更改,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
numpy系列之?dāng)?shù)組重塑的實現(xiàn)
本文主要介紹了numpy數(shù)組重塑。所謂數(shù)組重塑就是更改數(shù)組的形狀,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
Python+matplotlib+numpy實現(xiàn)在不同平面的二維條形圖
這篇文章主要介紹了Python+matplotlib+numpy實現(xiàn)在不同平面的二維條形圖,具有一定借鑒價值,需要的朋友可以參考下2018-01-01

