UnicodeEncodeError: 'ascii' codec can't encode character....

轉自:http://blog.csdn.net/zuyi532/article/details/8851316

python2.7

sql_text = 'insert into gia_list(gia,diamond_ct,ornament,order_no,order_price,customer_name,saler_name,curr_status,op_time,memo) valuses({0},{1},{2},{3},{4},{5},{6},{7},{8},{9})'
sql_text = sql_text.format(gia,diamond_ct,ornament,order_no,order_price,customer_name,saler_name,status,op_time,memo)
print sql_text
執行時報下面的錯誤:
sql_text = sql_text.format(gia,diamond_ct,ornament,order_no,order_price,customer_name,saler_name,status,op_time,memo)
UnicodeEncodeError: 'ascii' codec can't encode character u'\u65e0' in position 0: ordinal not in range(128)

在python在安裝時,默認的編碼是ascii,當程序中出現非ascii編碼時,python的處理常常會報這樣的錯,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啓動的時候,自行調用該文件,設置系統的默認編碼,而不需要每次都手動的加上解決代碼,屬於一勞永逸的解決方法。

另外有一種解決方案是在程序中所有涉及到編碼的地方,強制編碼爲utf8,即添加代碼encode("utf8"),這種方法並不推薦使用,因爲一旦少寫一個地方,將會導致大量的錯誤報告。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章