python報錯問題解決:'ascii' codec can't encode character

散盡浮華發表於2016-09-21

 

之前部署了openstack虛擬化環境,有一天在使用nova list檢視虛擬機器的時候,突然報錯!如下:

[root@linux-node1 src]# nova list
ERROR (UnicodeEncodeError): 'ascii' codec can't encode character u'\uff08' in position 9: ordinal not in range(128)

python在安裝時,預設的編碼是ascii,當程式中出現非ascii編碼時,python的處理常常會報這樣的錯,python沒辦法處理非ascii編碼的,此時需要自己設定將python的預設編碼,一般設定為utf8的編碼格式。

查閱網上,可以在程式中修改所有涉及到編碼的地方,強制編碼為utf8,即新增程式碼encode("utf8"),這種方法並不推薦使用,因為一旦少寫一個地方,將會導致大量的錯誤報告。

-------------------------------------------------
這裡介紹一個一次性修改後永久生效的方法:
在python的lib\site-packages資料夾下新建一個sitecustomize.py
[root@linux-node1 nova]# find / -name site-packages
/usr/lib/python2.7/site-packages
/usr/lib64/python2.7/site-packages

[root@linux-node1 nova]# cd /usr/lib/python2.7/site-packages/
[root@linux-node1 site-packages]# cat sitecustomize.py #新增如下內容,設定編碼為utf8
# encoding=utf8
import sys

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

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

[root@linux-node1 nova]# python                                       #終端進入python,即是重啟python直譯器!可以多次進入
Python 2.7.5 (default, Aug 18 2016, 15:58:25)
[GCC 4.8.5 20150623 (Red Hat 4.8.5-4)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>>

接著,再次使用nova list命令,就沒有那個報錯了!
[root@linux-node1 src]# nova list
+--------------------------------------+----------------------------+--------+------------+-------------+--------------------+
| ID | Name | Status | Task State | Power State | Networks |
+--------------------------------------+----------------------------+--------+------------+-------------+--------------------+
| b6a4738d-7e01-4068-a09b-7008b612d126 | beta-new1(beta環境1) | ACTIVE | - | Running | flat=192.168.1.151 |
| 9acdb28b-02c2-41bb-87c4-5f3a8fa008ab | dev-new-test1(測試環境1) | ACTIVE | - | Running | flat=192.168.1.150 |
| 30e5ba3e-3942-4119-9ba6-7523cf865b6f | kvm-server003 | ACTIVE | - | Running | flat=192.168.1.152 |
| a2893208-3ec9-4606-ab82-d7a870206cb9 | kvm-server004 | ACTIVE | - | Running | flat=192.168.1.153 |
| 3483d9f1-4015-48d9-9837-b67ca82dd54d | kvm-server005 | ACTIVE | - | Running | flat=192.168.1.154 |
+--------------------------------------+----------------------------+--------+------------+-------------+--------------------+

===================================================================
注意:上面是python7環境下的報錯解決方案,如果換成python6會怎麼解決呢?

如果是python6環境報這個錯誤,則/usr/lib/python2.6/site-packages下是沒有這個sitecustomize.py檔案的。
那麼這個時候就要看具體的報錯檔案了,在該檔案的程式碼開頭處新增如下程式碼:
import sys
reload(sys)
sys.setdefaultencoding('utf8')


比如,在jumpserver介面裡推送系統使用者的時候報錯:
ERROR (UnicodeEncodeError): 'ascii' codec can't encode character u'\uff08' in position 9: ordinal not in range(128)
從報錯介面裡找出錯誤所在的檔案是/data/jumpserver/jperm/ansible_api.py

則解決辦法:
[root@jumpserver01 ~]# cp /data/jumpserver/jperm/ansible_api.py /data/jumpserver/jperm/ansible_api.py.bak
[root@jumpserver01 ~]# vim /data/jumpserver/jperm/ansible_api.py
# -*- coding: utf-8 -*-

import sys                         #也就是在該檔案程式碼開頭新增這三行內容
reload(sys)
sys.setdefaultencoding('utf8')

然後再在jumpserver介面裡進行系統使用者推送操作,就不會報這個錯誤了!

相關文章