国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

徹徹底底地理解Python中的編碼問題

2020-02-15 23:12:41
字體:
來源:轉載
供稿:網友

Python處理文本的功能非常強大,但是如果是初學者,沒有搞清楚python中的編碼機制,也經常會遇到亂碼或者decode error。本文的目的是簡明扼要地說明python的編碼機制,并給出一些建議。

問題1:問題在哪里?

問題是我們的靶子,心中沒有問題去學習就會抓不住重點。

本文使用的編程環境是centos6.7,python2.7。我們在shell中鍵入python以打開python命令行,并鍵入如下兩句話:

 s = "中國zg" e = s.encode("utf-8")

現在的問題是:這段代碼能運行嗎?

答案是不能,會報如下的錯:

UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 0: ordinal not in range(128)

請留意一下錯誤中說明的0xe4,它是我們分析錯誤的突破口。

相信很多人都遇到過這個錯誤。那么新的問題來了。

問題2:Why?

要搞清楚原因,我們不妨認真分析下這兩句話的執行流程:

首先,我們通過鍵盤在python命令行解釋器中鍵入了 中國zg 并且給它加上了英文的雙引號,然后又賦值給了變量s,看起來很稀松平常是不是?其實里面大有玄機。

當我們通過鍵盤在程序中輸入字符時,我們是通過操作系統完成這個功能的。我們在屏幕上看到的 中國zg 實際上是操作系統給我們人類的一個反饋,告訴你:“嗨,哥們,你在程序中輸入了字符 中國zg ”

那操作系統給程序的反饋是什么呢?答案就是01串,這個01串是什么樣子,又是怎么生成的呢?

答案就是操作系統使用自己的默認編碼方式,將中國zg進行了編碼,并把編碼后的01串給了程序。

我們用的centos系統默認的編碼是utf-8,所以,只要知道中國zg每個字符的utf-8的編碼就可以知道01串是什么了。

查詢后,可以獲得它們的編碼是(以16進制和2進制表示):

z g
E4B8AD E59BBD 7A 67
11100101 10011011 10111101 11100101 10011011 10111101 01111010 01100111

現在我們知道操作系統傳給程序的01串長什么樣子了。然后,程序會怎么處理它呢?

程序看到這個01串被雙引號包圍著,自然知道這個01串是一個字符串。然后這個字符串被賦值給了s。

到此,就是第一句的執行邏輯。

現在繼續進行第二句的執行。

e = s.encode("utf-8")的意思是將字符串s用utf-8進行編碼,并將編碼后的字符串賦值給e。問題來了,程序現在知道s中的01串,還知道這個01串表示的是字符串,但這個字符串的編碼是什么呢?我們必須知道01串的現有編碼才能解析出里面的字符,也才能用新的編碼方式,如utf-8來重新編碼它。操作系統只給程序傳來了01串,并沒有告訴程序這個01串用的字符編碼是什么。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宝清县| 岗巴县| 麻城市| 始兴县| 福泉市| 延津县| 苏州市| 梓潼县| 句容市| 万安县| 华宁县| 纳雍县| 长寿区| 屏边| 大化| 渭南市| 皋兰县| 枣庄市| 景德镇市| 百色市| 凤台县| 卢龙县| 乐清市| 巴马| 游戏| 苏尼特左旗| 潜山县| 甘泉县| 买车| 兰州市| 汶川县| 石阡县| 珠海市| 交口县| 通辽市| 桂东县| 宁化县| 永嘉县| 嘉荫县| 靖宇县| 华安县|