在代码文件中定义中文时,经常会遇到问题,要么编码错误,要么是无法正常打印显示。
例如,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中的中文正常显示方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持武林站长站。
新闻热点
疑难解答