亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

蚌埠市| 彭州市| 二手房| 张家港市| 浑源县| 固阳县| 阳新县| 平邑县| 宽城| 鹰潭市| 揭西县| 屏东市| 邵武市| 德格县| 万山特区| 滦南县| 金门县| 高密市| 黄骅市| 南陵县| 凤城市| 清河县| 沙河市| 安塞县| 佛坪县| 保康县| 繁昌县| 桦川县| 墨江| 那曲县| 崇阳县| 瓦房店市| 沙田区| 襄樊市| 乾安县| 酉阳| 浏阳市| 罗城| 新蔡县| 宕昌县| 兴国县|