答案就是用json模块:
例如:
import json
data=[{u'\u663e\u793a': [u'python', u'\u8bd5\u9a8c'], u'\u6570\u91cf': 22, u'\u8bed\u8a00': u'python'}]
data_c = u'\u663e\u793a'
print data
print data_c
res_data=json.dumps(data,ensure_ascii=False,encoding="gb2312")
print res_data
在没有进行格式转换时,输出为:
>>>[{u'\u663e\u793a': [u'python', u'\u8bd5\u9a8c'], u'\u6570\u91cf': 22, u'\u8bed\u8a00': u'python'}]
>>>显示
可见非列表中的数据在输出时是会转换成中文显示出来的,但列表中的unicode数据不会。
转换后,输出为:
>>>[{"显示": ["python", "试验"], "数量": 22, "语言": "python"}]
如果后面这种输出是想要的格式,那么就利用现成的json模块将原列表格式转换为json字符串输出,并设置好编码格式,就可以了。
当还需要再用这部分用来显示的数据,譬如以后什么时候又想直接用python来读取log文件中这种看起来比较方便的带中文的伪列表,那么再用json.loads转换回去即可。