91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python編碼為什么出現中文亂碼

發布時間:2020-08-25 09:52:49 來源:億速云 閱讀:160 作者:Leah 欄目:編程語言

本篇文章為大家展示了python編碼為什么出現中文亂碼,代碼簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

首先明確幾個概念:

字節流:以utf8/gbk等編碼編碼的字節流。

unicode對象:python代碼中,a=u'中國', 或者a='中國'.decode()的結果。

terminal用于顯示字符的編碼:將一個用utf8/gbk編碼的字節流通過terminal指定的編碼,去查找對應的字符顯示出來。

locale:linux下,Locale 是軟件在運行時的語言環境, 它包括語言(Language), 地域 (Territory) 和字符集(Codeset)。一個locale的書寫格式為: 語言[_地域[.字符集]]. 所以說呢,locale總是和一定的字符集相聯系的。比如:zh_CN.GB2312

編碼轉換原則:unicode是"中介",任何編碼之間轉換都需要先decode()到unicode。

針對python,先把結論放在前面,三點:

#coding:utf-8 #.py文件是什么編碼就需要告訴python用什么編碼去讀取這個.py文件。

sys.stdout.encoding,默認就是locale的編碼,print會用sys.stdout.encoding去encode()成字節流,交給terminal顯示。所以locale需要與terminal一致,才能正確print打印出中文。

sys.setdefaultencoding(‘utf8’),用于指定str.encode() str.decode()的默認編碼,默認是ascii。

對編碼字符串a,代碼中可以直接寫a.encode(“gbk”),但事實上內部自動先通過defaultencoding 去decode成unicode之后再encode()的。

str(xxx)應該也是用這個去編碼的。

'ascii' codec can't encode characters in position 7-8: ordinal not in range(128)print的時候出現這個錯誤一般可以使用這個方案去處理。

為了避免代碼中到處都要去encode(“xxx”),還有可能不同的地方寫得不一樣帶來不一致的情況,推薦使用這個:

import sys   
reload(sys)   
sys.setdefaultencoding('utf8')

上述內容就是python編碼為什么出現中文亂碼,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

濉溪县| 祁门县| 汨罗市| 沐川县| 徐水县| 安陆市| 翁源县| 华容县| 阳信县| 雷州市| 濮阳县| 邹城市| 太仆寺旗| 余干县| 肥城市| 岱山县| 和林格尔县| 万全县| 阿克苏市| 攀枝花市| 鄂尔多斯市| 渝中区| 观塘区| 博罗县| 巫山县| 苗栗县| 宜阳县| 鸡东县| 来凤县| 莒南县| 大悟县| 池州市| 射阳县| 义马市| 祁门县| 泽州县| 闸北区| 沙河市| 江华| 河源市| 大石桥市|