在代碼檔案中定義中文時,經常會遇到問題,要麼編碼錯誤,要麼是無法正常列印顯示。
例如,dict_chinese.py:
#!/usr/bin/pythona={'name': 'fengshou'}b={'name': "豐收"}print "a=", aprint "b=", b
問題1
執行,查看結果
$ python dict_chinese.py File "dict_chinese.py", line 5SyntaxError: Non-ASCII character '\xe4' in file dict_chinese.py on line 5, but no encoding declared; see http://www.python.org/peps/pep-0263.html for details
原因
這是python編碼的問題, python中預設的編碼格式是ASCII格式, 所以預設是情況下無法正確編碼漢字。 解決辦法
定義編碼格式。
在以後的每一個需要顯示漢字的python檔案中,首先定義編碼格式,並且位置要求必須是在第一行或者第二行,如果第一行是#!/usr/bin/python,那麼在第二行定義,其他在第一行定義。
以utf-8編碼為例。
代碼修改為:
#!/usr/bin/python#-*-coding:utf-8 -*-a={'name': 'fengshou'}b={'name': '豐收'}print "a=", aprint "b=", b
問題2
執行,查看輸出:
$ python dict_chinese.py a= {'name': 'fengshou'}b= {'name': '\xe4\xb8\xb0\xe6\x94\xb6'}
可以看到中文內容仍然無法正常顯示。 解決辦法
使用json進行格式轉換,然後列印輸出。
代碼修改為:
#!/usr/bin/python#-*-coding:utf-8 -*-a={'name': 'fengshou'}b={'name': '豐收'}print "a=", aprint "b=", bimport jsonresult = json.dumps(b, encoding='UTF-8', ensure_ascii=False)print "b=", result
$ python dict_chinese.pya= {'name': 'fengshou'}b= {'name': '\xe4\xb8\xb0\xe6\x94\xb6'}b= {"name": "豐收"}
終於可以正常查看中文了。 參考
https://segmentfault.com/a/1190000002447836
http://blog.csdn.net/ksearch/article/details/35241019