實際程式設計中必定要會遇到編碼問題。
python在安裝時,預設的編碼是ascii,當程式中出現非ascii編碼時,python的處理常常會報這樣的錯unicodedecodeerror: 'ascii' codec can't decode byte 0x?? in position 1: ordinal not in range(128),python沒辦法處理非ascii編碼的,此時需要自己設定將python的預設編碼,一般設定為utf8的編碼格式。
查詢系統預設編碼可以在直譯器中輸入以下命令:
>>>sys.getdefaultencoding()
設定預設編碼時使用:
>>sys.setdefaultencoding('utf8')
可能會報attributeerror: 'module' object has no attribute 'setdefaultencoding'的錯誤,執行reload(sys),在執行以上命令就可以順利通過。
此時在執行sys.getdefaultencoding()就會發現編碼已經被設定為utf8的了,但是在直譯器裡修改的編碼只能保證當次有效,在重啟直譯器後,會發現,編碼又被重置為預設的ascii了,那麼有沒有辦法一次性修改程式或系統的預設編碼呢。
第一種方法:
import sys
reload(sys)
sys.setdefaultencoding('utf8')
第二種方法:
另乙個方案是在python的lib\site-packages資料夾下新建乙個sitecustomize.py,內容為:
# encoding=utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')
此時重啟python直譯器,執行sys.getdefaultencoding(),發現編碼已經被設定為utf8的了,多次重啟之後,效果相同,這是因為系統在python啟動的時候,自行呼叫該檔案,設定系統的預設編碼,而不需要每次都手動的加上解決**,屬於一勞永逸的解決方法。
另外有一種解決方案是在程式中所有涉及到編碼的地方,強制編碼為utf8,即新增**encode("utf8"),這種方法並不推薦使用,因為一旦少寫乙個地方,將會導致大量的錯誤報告。
Python 設定系統預設編碼
python在安裝時,預設的編碼是ascii,當程式中出現非ascii編碼時,python的處理常常會報這樣的錯unicodedecodeerror ascii codec can t decode byte 0x?in position 1 ordinal not in range 128 pyt...
Python 設定系統預設編碼
1.coding utf 8 作用是定義源 的編碼.如果沒有定義,此原始碼中是不可以包含中文字串的.pep 0263 defining python source code encodings 2.sys.getdefaultencoding 是設定預設的string的編碼格式 python在安裝時...
Python設定系統預設編碼
python預設的系統編碼為ascii編碼,在日程的編碼中經常會碰到python的編碼問題,為了一勞永逸的解決這個問題,可以將python的系統預設編碼設定為utf 8。unicodeencodeerror ascii codec can t encode characters in positio...