有人可以识别这些 bytes
的表示法是什么吗?乍一看,我倾向于认为“十六进制”,但我不认识像xf1Y
和e1fl
这样的东西是什么:
b'vy\xe9\xb5\xa2\xba\xf1Y\xe8\xe1fl\x1d\x87\xacC'
当我使用 some_text.encode('utf-8')
编码时,我得到了这个。
我正在尝试获取可以传递给使用 Python 2 字节字符串的加密方法的字节。
最佳答案
你是对的——这是一个十六进制表示法。
在字节字面量中,任何不能用可打印的 ASCII 字符(或标准转义字符 \n
、\t
或 \r
) 表示为 \xNN
,其中 NN 是字节的 2 位十六进制表示。
让您感到困惑的是您弄错了,例如\xf1Y
用于单个转义序列,而实际上它代表两个单独的字节:
>>> len(b'\xf1Y')
2
>>> [bytes([b]) for b in b'\xf1Y']
[b'\xf1', b'Y']
如果你迭代一个字节对象,你会得到字节的整数值:
>>> list(b'vy\xe9\xb5\xa2\xba\xf1Y\xe8\xe1fl\x1d\x87\xacC')
[118, 121, 233, 181, 162, 186, 241, 89, 232, 225, 102, 108, 29, 135, 172, 67]
>>> bytes([118])
b'v'
>>> bytes([121])
b'y'
>>> bytes([233])
b'\xe9'
escape sequences in Python string and bytes objects 的文档有更多关于 Python 理解的转义序列的信息(尽管上面那些是它用来表示字节对象的唯一信息)。
关于python - Python 3 字节的奇怪符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41421501/