字符串里的u'\u00a1'怎么打印成中文

现在有一个字符串,值就是:

demo = """
[u'\u2019\u2018 \u5fc5\u987b\u4e3a\u5408\u6cd5\u7684\u65e5\u671f\u683c\u5f0f\uff0c\u8bf7\u4f7f\u7528 YYYY-MM-DD \u683c\u5f0f\u3002']
"""

现在我想把字符串里的unicode表示,打印成中文。这个怎么做呢?
就是要这样的效果:

demo = '''
[’‘ 必须为合法的日期格式,请使用 YYYY-MM-DD 格式。]
'''

这两个值之间怎么转换下呢?

阅读 8.5k
2 个回答

为什么又是这个问题……我至少见过不下十遍了 QAQ

demo.decode('unicode-escape')

当然限 Python 2,因为 Python 3 里边不会遇到这种字符串。

其实你的问题应该在上层。你不该得到这么个字符串然后想要怎么处理。你应该直接得到你想要的那个。

有个叫 uniout 的库,可以解决一些 Python 2 的 uXXXX 显示问题。

强烈建议使用 Python 3,从此不再烦恼中文处理。

print(demo[0].encode('gbk').decode('gbk'))
你看这样行不行。你要在文件里显示中文的话,也要文件编码格式支持的。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题