问题一: 将u'\u810f\u4e71'转换为'\u810f\u4e71' 方法: s_unicode = u'\u810f\u4e71' s_str = s_unicode.encode('unicode-escape').decode('string_escape') 问题二: 将'\u810f\u4e71'转换为u'\u810f\u4e71' 方法: s_str = '\u810f
问题一:
将u'\u810f\u4e71'转换为'\u810f\u4e71'
方法:
s_unicode = u'\u810f\u4e71'
s_str = s_unicode.encode('unicode-escape').decode('string_escape')
问题二:
将'\u810f\u4e71'转换为u'\u810f\u4e71'
方法:
s_str = '\u810f\u4e71's_unicode = s_str.decode('unicode-escape')
补充知识:Python最简单的解决列表中只打印UNICODE而不是中文字符的方法
答案就是用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转换回去即可。
以上这篇python将unicode和str互相转化的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。