也许这是一个菜鸟问题,但我正在通过 TCP 接收一些数据,当我查看字符串时,我得到以下信息:
\x00\r\xeb\x00\x00\x00\x00\x01t\x00
那个\r
字符是什么,t
in\x01t
是什么意思?
我试过谷歌搜索,但我不知道谷歌是为了什么......
谢谢。
也许这是一个菜鸟问题,但我正在通过 TCP 接收一些数据,当我查看字符串时,我得到以下信息:
\x00\r\xeb\x00\x00\x00\x00\x01t\x00
那个\r
字符是什么,t
in\x01t
是什么意思?
我试过谷歌搜索,但我不知道谷歌是为了什么......
谢谢。
\r
是回车符 (0x0d),t
是t
.
查看字符串中的二进制数据有时会令人困惑,尤其是当它们很长时,但您始终可以将其转换为一些更易于阅读的十六进制数据。
>>> data = '\x00\r\xeb\x00\x00\x00\x00\x01t\x00'
>>> ' '.join(["%02X" % ord(char) for char in data])
'00 0D EB 00 00 00 00 01 74 00'
此外,如果您只是将字节字符串解析为字段,只需忽略该字符串并直接使用struct
模块将其解包:
>>> import struct
>>> length, command, eggs, spam = struct.unpack('!BBi4s',data)
>>> #...whatever your fields really are
>>> print "len: %i\ncmd: %i\negg qty: %i\nspam flavor: '%s'" % (
... length, command, eggs, spam)
len: 0
cmd: 13
egg qty: -352321536
spam flavor: ' ☺t '
将数据显示为字符串时,可打印字符(如 't' 显示为字符,已知控制序列显示为转义符,其他字节显示为 \x## 形式。示例:
>>> s='\x74\x0d\x99'
>>> s
't\r\x99'
您可以使用以下命令转储十六进制形式:
>>> import binascii
>>> binascii.hexlify(s)
'740d99'