UnicodeEncodeError: 'ascii' codec can't encode characters in position 14-15: ordinal not in range(128)


   python在安裝時,默認的編碼是ascii,當程序中出現非ascii編碼時,python的處理常常會報類似這樣的錯誤。

UnicodeEncodeError: 'ascii' codec can't encode characters in position 14-15: ordinal not in range(128)

 

    python沒辦法處理非ascii編碼的,此時需要自己設置將python的默認編碼,一般設置為utf8的編碼格式。

    查詢系統默認編碼

import sys;sys.getdefaultencoding()

 

     設置默認編碼

import sys;sys.setdefaultencoding('utf8')

    可能會報AttributeError: 'module' object has no attribute 'setdefaultencoding'的錯誤,執行reload(sys),在執行以上命令就可以順利通過。

    此時在執行sys.getdefaultencoding()就會發現編碼已經被設置為utf8的了,但是在解釋器里修改的編碼只能保證當次有效,在重啟解釋器后,會發現,編碼又被重置為默認的ascii了,那么有沒有辦法一次性修改程序或系統的默認編碼呢。

    

    有兩種種方法設置python的默認編碼:

方法一:在程序中加入以下代碼:
Python代碼

1 import sys 
2 reload(sys) 
3 sys.setdefaultencoding('utf8') 


方法二:在python的Lib\site-packages文件夾下新建一個sitecustomize.py,內容為:
Python代碼 

# encoding=utf8 
import sys

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

 

注意:sitecustomize.py這個文件最好不要使用記事本這樣的工具創建。

此時重啟python解釋器,執行sys.getdefaultencoding(),發現編碼已經被設置為utf8的了,
多次重啟之后,效果相同,這是因為系統在python啟動的時候,自行調用該文件,設置系統的默認編碼,
而不需要每次都手動的加上解決代碼,屬於一勞永逸的解決方法。

 


免責聲明!

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



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