在Python 3中,将字节转换为十六进制字符串的正确方法是什么?
我看到一个字节的声明。十六进制方法,bytes.decode编解码器,并尝试了其他可能的最小惊讶函数,但没有任何效果。我只想要我的字节为十六进制!
在Python 3中,将字节转换为十六进制字符串的正确方法是什么?
我看到一个字节的声明。十六进制方法,bytes.decode编解码器,并尝试了其他可能的最小惊讶函数,但没有任何效果。我只想要我的字节为十六进制!
当前回答
它可以使用格式说明符%x02,该格式并输出一个十六进制值。例如:
>>> foo = b"tC\xfc}\x05i\x8d\x86\x05\xa5\xb4\xd3]Vd\x9cZ\x92~'6"
>>> res = ""
>>> for b in foo:
... res += "%02x" % b
...
>>> print(res)
7443fc7d05698d8605a5b4d35d56649c5a927e2736
其他回答
如果你想将b'\x61'转换为97或'0x61',你可以尝试这样做:
[python3.5]
>>>from struct import *
>>>temp=unpack('B',b'\x61')[0] ## convert bytes to unsigned int
97
>>>hex(temp) ##convert int to string which is hexadecimal expression
'0x61'
参考:https://docs.python.org/3.5/library/struct.html
它可以使用格式说明符%x02,该格式并输出一个十六进制值。例如:
>>> foo = b"tC\xfc}\x05i\x8d\x86\x05\xa5\xb4\xd3]Vd\x9cZ\x92~'6"
>>> res = ""
>>> for b in foo:
... res += "%02x" % b
...
>>> print(res)
7443fc7d05698d8605a5b4d35d56649c5a927e2736
import codecs
codecs.getencoder('hex_codec')(b'foo')[0]
适用于Python 3.3(因此“hex_codec”而不是“hex”)。
Python有字节到字节的标准编解码器,可以执行方便的转换,如引号-printable(适合7bits ascii), base64(适合字母数字),十六进制转义,gzip和bz2压缩。在Python 2中,你可以这样做:
b'foo'.encode('hex')
在Python 3中,str.encode / bytes.decode严格用于bytes<->的str转换。相反,你可以这样做,它可以在Python 2和Python 3之间工作(s/encode/decode/g为逆):
import codecs
codecs.getencoder('hex')(b'foo')[0]
从Python 3.4开始,有一个不那么尴尬的选项:
codecs.encode(b'foo', 'hex')
这些misc编解码器也可以在它们自己的模块中访问(base64, zlib, bz2, uu, quopri, binascii);API不太一致,但对于压缩编解码器,它提供了更多的控制。
自Python 3.5以来,这终于不再尴尬:
>>> b'\xde\xad\xbe\xef'.hex()
'deadbeef'
和反向:
>>> bytes.fromhex('deadbeef')
b'\xde\xad\xbe\xef'
也适用于可变bytearray类型。
参考:https://docs.python.org/3/library/stdtypes.html # bytes.hex