Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/python-3.x/17.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
什么';在Python3中,将字节转换为十六进制字符串的正确方法是什么?_Python_Python 3.x_Hex - Fatal编程技术网

什么';在Python3中,将字节转换为十六进制字符串的正确方法是什么?

什么';在Python3中,将字节转换为十六进制字符串的正确方法是什么?,python,python-3.x,hex,Python,Python 3.x,Hex,在Python3中,将字节转换为十六进制字符串的正确方法是什么 我看到了bytes.hex方法、bytes.decode编解码器的说法,并尝试了一些可能的功能,但毫无效果。我只希望我的字节是十六进制 使用binascii模块: >>> import binascii >>> binascii.hexlify('foo'.encode('utf8')) b'666f6f' >>> binascii.unhexlify(_).decode('ut

在Python3中,将字节转换为十六进制字符串的正确方法是什么


我看到了
bytes.hex
方法、
bytes.decode
编解码器的说法,并尝试了一些可能的功能,但毫无效果。我只希望我的字节是十六进制

使用
binascii
模块:

>>> import binascii
>>> binascii.hexlify('foo'.encode('utf8'))
b'666f6f'
>>> binascii.unhexlify(_).decode('utf8')
'foo'
看看这个答案:

Python具有字节到字节的转换,可以执行方便的转换,如引号可打印(适合7位ascii)、base64(适合字母数字)、十六进制转义、gzip和bz2压缩。在Python 2中,您可以执行以下操作:

b'foo'.encode('hex')
在Python3中,
str.encode
/
字节.decode
严格用于bytesstr转换。相反,您可以这样做,它可以跨Python 2和Python 3工作(s/encode/decode/g表示相反):

从Python 3.4开始,有一个不那么尴尬的选项:

codecs.encode(b'foo', 'hex')
这些杂项编解码器也可在其自身模块(base64、zlib、bz2、uu、quopri、binascii)内访问;API的一致性较差,但对于压缩编解码器,它提供了更多的控制

import codecs
codecs.getencoder('hex_codec')(b'foo')[0]

在Python3.3中工作(因此“hex_codec”而不是“hex”)。

方法
binascii.hexlify()
字节转换为表示ascii十六进制字符串的
字节。这意味着输入中的每个字节将转换为两个ascii字符。如果你想要一个真正的
str
输出,那么你可以
解码(“ascii”)
结果

我包括了一个片段来说明这一点

import binascii

with open("addressbook.bin", "rb") as f: # or any binary file like '/bin/ls'
    in_bytes = f.read()
    print(in_bytes) # b'\n\x16\n\x04'
    hex_bytes = binascii.hexlify(in_bytes) 
    print(hex_bytes) # b'0a160a04' which is twice as long as in_bytes
    hex_str = hex_bytes.decode("ascii")
    print(hex_str) # 0a160a04

从十六进制字符串
“0a160a04”
到可以使用
binascii.unexlify(“0a160a04”)
返回
b'\n\x16\n\x04'

,从Python 3.5开始,这终于不再尴尬了:

>>> b'\xde\xad\xbe\xef'.hex()
'deadbeef'
反过来说:

>>> bytes.fromhex('deadbeef')
b'\xde\xad\xbe\xef'
也适用于可变的
bytearray
类型


参考:

如果要将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'

参考资料:

好的,如果您只关心Python 3,那么下面的答案稍微超出了范围,但是即使您没有指定Python版本,这个问题也是Google首次提出,因此这里有一种同时适用于Python 2和Python 3的方法

我还将问题解释为如何将字节转换为
str
类型:即,Python 2上的bytes-y和Python 3上的Unicode-y

鉴于此,我所知道的最佳方法是:

import six

bytes_to_hex_str = lambda b: ' '.join('%02x' % i for i in six.iterbytes(b))
假设您没有在Python 2中激活
unicode\u文本
future,则以下断言对于Python 2或Python 3都是正确的:

assert bytes_to_hex_str(b'jkl') == '6a 6b 6c'

(或者您可以使用
'.join()
来省略字节之间的空格等)

可以使用格式说明符
%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

Python3.8中的新功能是,可以将分隔符参数传递给
hex
函数,如本例所示

>>> value = b'\xf0\xf1\xf2'
>>> value.hex('-')
'f0-f1-f2'
>>> value.hex('_', 2)
'f0_f1f2'
>>> b'UUDDLRLRAB'.hex(' ', -4)
'55554444 4c524c52 4142'

“没有用”?您遇到了哪些具体问题或错误?请显示代码和错误。这可能是好的重复。令人难以置信的是,您可以使用bytes.fromhex(hex_str)将十六进制转换为字节,但无法使用bytes.tohex()将字节转换为十六进制-这其中的理性是什么?我猜字节和十六进制之间的关系不是这两者的属性(这无法回答为什么存在fromhex)。似乎这不仅仅是一个疏忽,而是一个争论不休的问题。问:让bytes对象的tohex方法也执行这项任务会有伤害吗?A:依我看,是的。它使代码复杂化,并将注意力从正确的数据转换方法(即函数-而不是方法)上移开。这真的回答了问题吗?它不返回十六进制
str
,而是返回
字节。我知道OP似乎对答案很满意,但如果将此答案扩展为包含
。decode(“ascii”)
,并将其转换为“字符串”,则不会更好。我想,许多人在这个问题/答案上寻找打印出
字节的方法。如果
print(b'666f6f')
则在打印输出中获得
b
。如果你
.decode(“ascii”)
那么你就不需要了。想一想那些实际有
字节的人(项目数>128的真正二进制,而不是ascii字符串)是如何打印出来的。@nagylzs:Python3.5+中有
.hex()
方法,使用Python3.3:
LookupError:未知编码:hex
@JanusTroelsen:试试看。或者直接使用
binascii.hexlify(b'foo')
也许有趣的是,在Python3.4中,“hex”或“hex_codec”可以很好地工作。在Python3.0+(不仅仅是3.5+)上也可以使用
bytes.hex()
仅在Python3.5+上使用。正如@TejasTank所说,它绝对能帮助我使用ESP32。这是唯一一种在很多库都不可用的microyton上使用的方法。据我所知,这是最好的答案,因为它适用于所有Python版本,并且不需要任何导入。但是,我最好用大写字母显示六进制字符串
res.upper()
>>> value = b'\xf0\xf1\xf2'
>>> value.hex('-')
'f0-f1-f2'
>>> value.hex('_', 2)
'f0_f1f2'
>>> b'UUDDLRLRAB'.hex(' ', -4)
'55554444 4c524c52 4142'