我正在学习Python编码,我遇到了下面的情况,这是为我而设的,我想知道为什么。
首先,这是我的环境:OSX10.10.3
命令echo $LC_CTYPE, $LANG的输出是:en_US.UTF-8, en_US.UTF-8
python --version的输出为Python 2.7.6
然后输入python输入python:
>>> import sys; reload(sys); sys.setdefaultencoding('utf8')
<module 'sys' (built-in)>
>>> s16 = u'我'.encode('utf16')
>>> s16
'\xff\xfe\x11b'
>>> for c in s16:
... ord(c)
...
255
254
17
98
>>> s16_ = '\xff\xfe\x11\x62'
>>> s16_
'\xff\xfe\x11b'所以我的问题是:对于最后一行和第4行,为什么Python输出'\xff\xfe\x11b'而不是'\xff\xfe\x11\x62'?
发布于 2015-07-30 15:14:03
当Python打印字节(Python2中的str)时,如果该字节是可打印的,它就会为该字节打印相应的ASCII字符,否则十六进制就会转义它。
\x62对应于ASCII 'b‘。只要看一下这个字节,就可以看到这一点:
>>> '\x62'
'b'发布于 2015-07-30 15:17:29
https://stackoverflow.com/questions/31727478
复制相似问题