用python檢視和更改系統預設編碼

2021-06-27 16:35:59 字數 1491 閱讀 3193

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.getdefaultencoding()
設定預設編碼時使用:

python** 

>>>sys.setdefaultencoding('utf8')  

>>>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')   

import sys  reload(sys)  sys.setdefaultencoding('utf8')
另乙個方案是在python的lib\site-packages資料夾下新建乙個sitecustomize.py,內容為:

python** 

# encoding=utf8   

import sys   

reload(sys)   

sys.setdefaultencoding('utf8')   

# encoding=utf8  import sys    reload(sys)  sys.setdefaultencoding('utf8')
此時重啟python直譯器,執行sys.getdefaultencoding(),發現編碼已經被設定為utf8的了,多次重啟之後,效果相同,這是因為系統在python啟動的時候,自行呼叫該檔案,設定系統的預設編碼,而不需要每次都手動的加上解決**,屬於一勞永逸的解決方法。

另外有一種解決方案是在程式中所有涉及到編碼的地方,強制編碼為utf8,即新增**encode("utf8"),這種方法並不推薦使用,因為一旦少寫乙個地方,將會導致大量的錯誤報告,我曾經遇到這種情況,錯誤日誌壓縮之後尚有70多k,全都是這乙個問題,讓人有很崩潰的感覺。

Linux 檢視和更改系統字符集

linux下如何去檢視當前系統字符集操作 echo lang en us.utf 8 env grep lang lang en us.utf 8 locale grep ctype lc ctype en us.utf 8 更改系統字符集 執行export lang 字符集名稱 或者export ...

更改Windows系統中DOS命令列的預設路徑

dos,disk operatingsystem。昔日微軟的磁碟作業系統,想必大家還沒忘記!雖然微軟windows系統橫行,但依然能找到它的蹤影。在windows中使用dos將更加人性化,不過一些預設屬性是不是干擾著你,如本文提及的dos初始預設路徑。不過沒關係,看過本文,你就可以左右它了!在win...

ubuntu系統更改預設Python版本

當你安裝 debian linux 時,安裝過程有可能同時為你提供多個可用的 python 版本,因此系統中會存在多個 python 的可執行二進位制檔案。你可以按照以下方法使用ls命令來檢視你的系統中都有那些 python 的二進位制檔案可供使用。python view plain copy ls...