问个简单的 python 问题

2014-07-30 11:17:10 +08:00
 zts1993
现有一字符串 \x47\x4cO\x42\x41\x4c\x53 utf8编码存在一个文件里面

print '\x47\x4cO\x42\x41\x4c\x53'.decode("utf-8") 结果是GLOBALS
print r'\x47\x4cO\x42\x41\x4c\x53'.decode("utf-8") 结果是\x47\x4cO\x42\x41\x4c\x53
为什么

我从file 中readline得到的结果个下面的一样 ==这个显然不是我要的结果,这又是为啥呢。
2488 次点击
所在节点    问与答
4 条回复
exoticknight
2014-07-30 11:47:39 +08:00
r代表raw string,就是字符中的"\"不代表转义
wwttc
2014-07-30 11:51:07 +08:00
使用:unicode_escape
print r'\x47\x4cO\x42\x41\x4c\x53'.decode("unicode_escape")
GLOBALS

https://docs.python.org/2/library/codecs.html
imn1
2014-07-30 12:02:07 +08:00
其实说粗一点 r 就是专为保留 \ 而用的
zts1993
2014-07-30 12:36:51 +08:00
@wwttc soga。

谢谢,就是这个~~

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/125231

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX