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()
設定預設編碼時使用:
python**
>>>sys.setdefaultencoding('utf8')
可能會報attributeerror: 'module' object has no attribute 'setdefaultencoding'的錯誤,執行reload(sys),在執行以上命令就可以順利通過。
此時在執行sys.getdefaultencoding()就會發現編碼已經被設定為utf8的了,但是在直譯器裡修改的編碼只能保證當次有效,在重啟直譯器後,會發現,編碼又被重置為預設的ascii了,那麼有沒有辦法一次性修改程式或系統的預設編碼呢。
有2種方法設定python的預設編碼:
乙個解決的方案在程式中加入以下**:
python**
import sys
reload(sys)
sys.setdefaultencoding('utf8')
另乙個方案是在python的lib\site-packages資料夾下新建乙個sitecustomize.py,內容為:
python**
# encoding=utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')
此時重啟python直譯器,執行sys.getdefaultencoding(),發現編碼已經被設定為utf8的了,多次重啟之後,效果相同,這是因為系統在python啟動的時候,自行呼叫該檔案,設定系統的預設編碼,而不需要每次都手動的加上解決**,屬於一勞永逸的解決方法。
設定編碼格式
1.控制層利用註解設定編碼格式 返回物件時用utf 8編碼,返回字串時用iso 8859 1格式 手動轉碼 2.設定響應編碼 response.setcontenttype text html charset utf 8 3.全域性字符集設定 tomcat中設定 在tomcat home conf ...
php mysql設定編碼格式
當我們通過php訪問mysql資料庫時,就算設定了表的預設字符集為utf8,並且通過utf 8編碼傳送查詢,你會發現存入資料庫的仍然是亂碼。問題就出在connection連線層上。解決方法是在傳送查詢前執行一下下面這句 1.set names utf8 它相當於下面的三句指令 set charact...
pl sql developer 編碼格式設定
一 pl sql developer 中文字段顯示亂碼 原因 因為資料庫的編號格式和pl sql developer的編碼格式不統一造成的。二 檢視和修改oracle資料庫字符集 select userenv language from dual 查詢結果 simplified chinese ch...