我正在尝试使用 unpack 将十六进制数转换为十进制数。 当我使用时:
from struct import *
unpack("<H",b"\xe2\x07")
输出是:2018
,这就是我想要的。
问题是我的十六进制数据以字符串形式存在于列表中,格式为:
asd = ['e2','07']
我的问题是有没有一种简单的方法可以使用 unpack 而不使用反斜杠 x?像这样:
unpack("<H","e207")
我知道这行不通,但我希望你明白。
为了澄清,我知道我可以在列表中获取 b'\x11'
形式的数据,但随后它会被解释为 ASCII,这是我不想要的,这就是我拥有它的原因按照我展示的格式。
最佳答案
您在文本对象中拥有十六进制编码的数据。因此,要返回原始十六进制字节,您可以对文本字符串进行解码。请注意,这不是 Python 3.x 中的常见约定(通常,文本字符串已经被解码)。
>>> codecs.decode('e207', 'hex')
b'\xe2\x07'
用于同一件事的便利函数:
>>> bytes.fromhex('e207')
b'\xe2\x07'
现在您可以struct.unpack
这些字节。把它们放在一起:
>>> asd = ['e2','07']
>>> text = ''.join(asd)
>>> encoded = codecs.decode(text, 'hex')
>>> struct.unpack("<H", encoded)
(2018,)
关于python-3.x - python 3 中的解包语法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53377529/