python為什么需要reload(sys)后設置編碼


python在安裝時,默認的編碼是ascii,當程序中出現非ascii編碼時,python的處理常常會報這樣的錯UnicodeDecodeError: 'ascii' codec can't decode byte 0x?? in position 1: ordinal not in range(128),python沒辦法處理非ascii編碼的,此時需要自己設置python的默認編碼,一般設置為utf8的編碼格式。
查詢系統默認編碼可以在解釋器中輸入以下命令:
Python代碼

sys.getdefaultencoding()

設置默認編碼時使用:

sys.setdefaultencoding('utf8')

可能會報AttributeError: 'module' object has no attribute 'setdefaultencoding'的錯誤,執行reload(sys),再執行以上命令就可以順利通過。
此時再執行sys.getdefaultencoding()就會發現編碼已經被設置為utf8的了,但是在解釋器里修改的編碼只能保證當次有效,在重啟解釋器后,會發現,編碼又被重置為默認的ascii了,那么有沒有辦法一次性修改程序或系統的默認編碼呢。

如果需要在運行時(就是整個解釋器啟動完之后)進行setdefaultencoding,就只能重新加載sys這個模塊。

一個解決的方案在程序中加入以下代碼:

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM