在代碼文件中定義中文時,經常會遇到問題,要么編碼錯誤,要么是無法正常打印顯示。
例如,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": "豐收"}
終于可以正常查看中文了。
以上這篇python 實現將字典dict、列表list中的中文正常顯示方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林站長站。
新聞熱點
疑難解答