2024-05-15 03:46:05 发布
网友
在Python 3中,将字节转换为十六进制字符串的正确方法是什么?
我看到了一个bytes.hex方法,bytes.decode编解码器的声明,并尝试了other可能的、最不令人吃惊的函数,但没有成功。我只想我的字节是十六进制的!
bytes.hex
bytes.decode
自从Python 3.5之后,这一点终于不再尴尬了:
>>> b'\xde\xad\xbe\xef'.hex() 'deadbeef'
和背面:
>>> bytes.fromhex('deadbeef') b'\xde\xad\xbe\xef'
也适用于可变的bytearray类型。
bytearray
引用:https://docs.python.org/3/library/stdtypes.html#bytes.hex
Python有字节到字节的standard codecs,它们执行方便的转换,如带引号的可打印(适合7bits ascii)、base64(适合字母数字)、十六进制转义、gzip和bz2压缩。在Python 2中,您可以执行以下操作:
b'foo'.encode('hex')
在Python 3中,str.encode/bytes.decode严格用于字节<;->;str转换。相反,您可以这样做,它可以在Python 2和Python 3中工作(s/encode/decode/gfor the inverse):
str.encode
import codecs codecs.getencoder('hex')(b'foo')[0]
从Python3.4开始,有一个不那么尴尬的选择:
codecs.encode(b'foo', 'hex')
这些misc编解码器也可以在它们自己的模块(base64、zlib、bz2、uu、quopri、Binasci)中访问;API不太一致,但对于压缩编解码器,它提供了更多的控制。
使用binascii模块:
binascii
>>> import binascii >>> binascii.hexlify('foo'.encode('utf8')) b'666f6f' >>> binascii.unhexlify(_).decode('utf8') 'foo'
请看这个答案: Python 3.1.1 string to hex
自从Python 3.5之后,这一点终于不再尴尬了:
和背面:
也适用于可变的
bytearray
类型。引用:https://docs.python.org/3/library/stdtypes.html#bytes.hex
Python有字节到字节的standard codecs,它们执行方便的转换,如带引号的可打印(适合7bits ascii)、base64(适合字母数字)、十六进制转义、gzip和bz2压缩。在Python 2中,您可以执行以下操作:
在Python 3中,
str.encode
/bytes.decode
严格用于字节<;->;str转换。相反,您可以这样做,它可以在Python 2和Python 3中工作(s/encode/decode/gfor the inverse):从Python3.4开始,有一个不那么尴尬的选择:
这些misc编解码器也可以在它们自己的模块(base64、zlib、bz2、uu、quopri、Binasci)中访问;API不太一致,但对于压缩编解码器,它提供了更多的控制。
使用
binascii
模块:请看这个答案: Python 3.1.1 string to hex
相关问题 更多 >
编程相关推荐