中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

原平市| 汨罗市| 华安县| 兴海县| 玉龙| 金川县| 开江县| 永善县| 扶余县| 客服| 南靖县| 谢通门县| 类乌齐县| 建阳市| 许昌县| 雷州市| 宾川县| 荥经县| 南丰县| 玉门市| 佳木斯市| 岱山县| 宜川县| 威远县| 洛南县| 鸡泽县| 东平县| 泊头市| 东乌珠穆沁旗| 基隆市| 琼结县| 长寿区| 射阳县| 长宁县| 洞口县| 扬州市| 临猗县| 白水县| 蚌埠市| 宁夏| 济南市|