您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關python如何解決編碼錯誤UnicodeEncodeError: 'ascii' codec can't encode characters in pos問題,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
相同代碼在一臺服務器上跑是OK的另外一個臺跑則報錯如下
File "/data/soft/knowledge_etl/databus-gedai-v1/schedule_job/main.py", line 270, in <module> print('demo\u4e3a\u5168\u90e8kp_md5_etl\u4e3b\u4efb\u52a1\u4e3a\u4f8b\u5b50') UnicodeEncodeError: 'ascii' codec can't encode characters in position 4-6: ordinal not in range(128)
#decode的作用是將其他編碼的字符串轉換成unicode編碼#python2s = u'中文's.decode('utf-8')print s#中文#python3#由于在python3中,所有的字符串都是使用Unicode編碼,統一使用str類型來保存,而str類型沒有decode(解碼)方法,所以報錯Traceback (most recent call last): File "tmp_2.py", line 4, in <module>s.decode('utf-8')AttributeError: 'str' object has no attribute 'decode'#附注:str類型有encode(編碼)方法#encode的作用是將unicode編碼轉換成其他編碼的字符串s1=u'哈咯'print(s1.encode('utf-8'))#b'\xe5\x93\x88\xe5\x92\xaf' #輸出編碼方式unicode的結果
#在終端打開python>>>a = b'\xe5\x94\xb1\xe6\xad\x8c'#unicode編碼方式,注意這里a并非字符串>>>a = a.decode("utf-8")#解碼>>>print(a)唱歌#排除字符編碼和代碼失誤
import sysprint(sys.stdout.encoding)#顯示:US-ASCII#現在找到問題所在了,是編輯器的環境使用的是US-ASCII編碼,所以會出錯##此方法應也可被用于查看print的輸出編碼
原因剖析:有時候進程的運行環境里,locale 會被設置成只支持 ASCII 字符集的(比如 LANG=C)。這時候 Python 就會把標準輸出和標準錯誤的編碼給設置成 ascii,造成輸出中文時報錯。在這里的 Visual Studio Code 編輯器中就被設置成了ascii編碼,造成輸出中文報錯。
import sysimport iodef setup_io():sys.stdout = sys.__stdout__ = io.TextIOWrapper(sys.stdout.detach(), encoding='utf-8', line_buffering=True)sys.stderr = sys.__stderr__ = io.TextIOWrapper(sys.stderr.detach(), encoding='utf-8', line_buffering=True)setup_io()#sys.stdout 是個 io.TextIOWrapper,有個 buffer 屬性,里邊是個 io.BufferedWriter。我們用它造一個新的 io.TextIOWrapper,指定編碼為 UTF-8。這里除了可以設置編碼之外,也可以設置錯誤處理和緩沖。所以這個技巧也可以用來容忍編碼錯誤、改變標準輸出的緩沖。s1='我想你了'print(s1)#我想你了~正確
以上就是python如何解決編碼錯誤UnicodeEncodeError: 'ascii' codec can't encode characters in pos問題,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。