欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

python與字符編碼問題

系統(tǒng) 1877 0

用python2的小伙伴肯定會遇到字符編碼的問題。下面對編碼問題做個簡單的總結(jié),希望對各位有些幫助。

故事零:編碼的定義

我們從“SOS“(國際通用求助信號)開始,它的摩斯密碼的編碼是:

“…---…”,想一下為什么選用S、O、S來作為求救信號?因?yàn)樗唵危菀妆鎰e且不容易發(fā)錯呀!
那么,字符編碼就是:

′給定一系列字符,對每個字符賦予一個數(shù)值,用數(shù)值來代表對應(yīng)的字符,這一數(shù)值就是字符的編碼。例如,我們給字符'A'賦予數(shù)值0x41,則0x41就是字符'A'的編碼。字符編碼是字符的表現(xiàn)、儲存方式。

字符編碼需要處理兩件事:

(1)規(guī)定一個字符集中的字符由多少個字節(jié)表示;

(2)制定該字符集的字符編碼表,即該字符集中每個字符對應(yīng)的(二進(jìn)制)值。

字符集:′給定一系列字符并賦予對應(yīng)的編碼后,所有這些字符和編碼對組成的集合就是字符集。′比如,給定字符列表為{'A','B'}時(shí),{'A'=>0x41,‘B'=>0x42}就是一個字符集。

常見字符集有:

ASCII
GB2312
GBK
GB18030
Big5
Unicode

一張圖總結(jié):

故事一:Python2與Python3的字符串類型?

python2中的字符串有str和unicode類型,而python3中字符串只有unicode類型。比如?‘你好'是str字符串,而?u'你好'則是unicode字符串。

故事二:decode()和encode()傻傻分不清?

decode()?是將str字符串轉(zhuǎn)化為unicode字符串;encode()?是將unicode字符串轉(zhuǎn)化為str字符串。所以要做一些編碼的轉(zhuǎn)換通常是以unicode作為中間編碼做轉(zhuǎn)換。如name.decode(“GB2312”)表示將GB2312編碼的字符串name轉(zhuǎn)換成unicode編碼,name.encode(“GB2312”)表示將unicode字符串name轉(zhuǎn)換成GB2312編碼。

python與字符編碼問題_第1張圖片

故事三:UnicodeEncodeError: ‘a(chǎn)scii' codec can't encode character?

我們先看看兩張圖,是不是很煩?

python與字符編碼問題_第2張圖片

python與字符編碼問題_第3張圖片

下面我們看個例子:

當(dāng)用u'字符串'申明這個字符串變量時(shí)就指明了該字符串是使用unicode字符編碼。當(dāng)要將unicode字符串轉(zhuǎn)換為str字符串或者寫入文件時(shí),python2默認(rèn)使用ASCII?碼保存數(shù)據(jù),而ASCII?碼無法識別大于128?的字符,于是報(bào)了上面的錯誤。
附ASCII碼表:

python與字符編碼問題_第4張圖片

故事四:unicode是什么?

unicode可以看做一個終極的字符編碼方法,它給出了地球上常用字符的二進(jìn)制映射,而且所有的二進(jìn)制字符串唯一地表示一個字符。但是,unicode只給出了字符和二進(jìn)制串的對應(yīng)關(guān)系,并沒有給出存儲形式。而不同字符所占用的存儲空間可能不同,比如ASCII?在unicode中只占用了一個字節(jié)即可,而常用漢字在unicode中需要占用兩個字節(jié),還有一些羅馬字符可能需要三個或以上字節(jié)。如果直接存儲的話可能導(dǎo)致無法分割字符串,也無法正確解碼出字符。

故事五:UTF-8橫空出世?

互聯(lián)網(wǎng)的普及,強(qiáng)烈要求出現(xiàn)一種統(tǒng)一的編碼方式。這時(shí)候UTF-8?出場。UTF-8?是unicode在計(jì)算機(jī)中的一種實(shí)現(xiàn)方式。UTF-8是一種變長編碼,每個字符占1-4?個字節(jié)。UTF-8?將字節(jié)分為數(shù)值位和標(biāo)識位,數(shù)值位真正保存字符編碼數(shù)值,標(biāo)識位表示這個字節(jié)是屬于哪個字符的、或者該字符占多少個字節(jié)。UTF-8?編碼方法:

單字節(jié),首位為標(biāo)識位0;多字節(jié)字符首字節(jié)標(biāo)志位1??10開頭,字符占多少字節(jié)則有多少1,其他字節(jié)標(biāo)識位10開頭;

§??單字節(jié)字符:?0xxxxxxx?(以0?開頭標(biāo)志位,數(shù)值位用x?表示)

§??雙字節(jié)字符:?110xxxxx 10xxxxxx

§??三字節(jié)字符:?1110xxxx 10xxxxxx 10xxxxxx

§??四字節(jié)字符:?11110xxx 10xxxxxx 10xxxxxx10xxxxxx

unicode變?yōu)閁TF-8?編碼非常簡單,unicode二進(jìn)制按照從低到高,填充UTF-8的數(shù)值位,除去那些不真正表示數(shù)值的標(biāo)識位(字節(jié)開頭的0,10,110,1110和11110),順序也是由低到高。以漢字“你”為例,可見它的unicode編碼為“4f60”(01001111 01100000)。

從“你”的unicode值范圍可以看到需要三個字節(jié),接著從低位字節(jié)向高位字節(jié)填充得到“你”的UTF-8?編碼(高位沒有填充完則用0補(bǔ)充)。

可以看到將UTF-8?用于標(biāo)記位(紅色)的位去掉,合并可以得到原始的unicode碼。

故事六:"unicode-escape"與"unicode-unescape"

“\u”是表示unicode的轉(zhuǎn)義字符,用\uxxxx這種方式表示unicode字符就是”unicode-escape”方式。說人話:′一句話:xxx.decode(“unicode-escape”)相當(dāng)于把xxx解碼成unicode類型并返回。
而用”%uxxxx”的方式表示unicode字符,這種方式就是”unicode-unescape”,常用于javascript。

番外故事七:讀了那么多年書,你真的了解“全半角”?

全角---指一個字符占用兩個標(biāo)準(zhǔn)字符位置。
半角---指一字符占用一個標(biāo)準(zhǔn)的字符位置。
引申:寫程序時(shí)雙引號、冒號、小括號等為啥如此糾結(jié)?
--我國專家在制定GB2312字符集時(shí),ASCII里本來就有的數(shù)字、標(biāo)點(diǎn)、字母都統(tǒng)統(tǒng)重新編了兩個字節(jié)長的編碼。
是不是腦殼疼呀,想想我國程序員因?yàn)橹杏⑽那袚Q犧牲了多少寶貴時(shí)間啊,啊嘿!

總結(jié)

以上所述是小編給大家介紹的python與字符編碼問題 ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: bt日韩| 亚洲视频免费 | 欧美一区二区三区四区夜夜大片 | 一区二区日韩精品 | 亚洲精品自产拍在线观看app | 欧美人与禽性xxxxx杂性 | 九九热久久免费视频 | 亚洲综合视频一区 | 九九色影院 | 亚洲一区国产 | 久久精品中文字幕 | 啪啪天堂 | 日本老妇人乱视频 | 日本福利一区 | 欧美视频综合 | 亚洲欧美日韩一区二区在线观看 | 国产一区二区欧美丝袜 | 免费v片 | 精品一区二区三区中文字幕 | 日本免费观看官网 | 国产亚洲女人久久久久久 | 欧美成人手机视频 | 日韩欧美亚洲 | 91看片在线免费观看 | 免费在线观看成人 | 神马久久久久久久久 | 日韩国产在线 | 手机国产日韩高清免费看片 | 欧美经典一区 | 欧美综合自拍亚洲综合网 | av网站在线看 | 精品久久影院 | 欧美日韩一区二区三区在线观看 | 欧美精品一区二区三区蜜桃视频 | 亚洲婷婷在线 | 久久精品国产一区 | 国产精品久久久久久久久免费 | 日韩三级欧美 | 免费一级片在线观看 | 色综合久久久久久久久五月性色 | 天堂热 |