解決python編碼格式錯誤問題


一:前言

遇到問題:print輸入漢字時提示錯誤信息 UnicodeDecodeError: 'ascii' codec can't decode byte 0x?? in position 1: ordinal not in range(128)

1:windows環境下

2:腳本已備注:# -*- coding:utf-8 -*-

 

二:查找解決辦法

1:了解python編碼格式

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

2:如何查詢python的編碼格式

     

3:設置python默認編碼格式

    

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

     

  此時在執行sys.getdefaultencoding(),就會發現編碼已經設置為utf-8了,但是在解釋器里修改的編碼只能保證檔次有效,在重啟編譯器后,編碼又被重置為默認的ascii了

4:一個永久解決的辦法

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

     

    此時重啟python解釋器,執行sys.getdefaultencoding(),發現編碼已經被設置為utf8的了,多次重啟之后,效果相同。

    這是因為系統在python啟動的時候,自行調用該文件,設置系統的默認編碼,而不需要每次都手動的加上解決代碼。

 

三:檢驗是否解決

    輸出漢字已經不再報錯誤了,問題解決了。

     

 

參考源文件:http://blog.csdn.net/zuyi532/article/details/8851316  

   


免責聲明!

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



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