python 3中的解包语法

Posted

技术标签:

【中文标题】python 3中的解包语法【英文标题】:unpack syntax in python 3 【发布时间】:2018-11-19 15:10:40 【问题描述】:

我正在尝试使用 unpack 将十六进制数转换为十进制数。 当我使用时:

from struct import *
unpack("<H",b"\xe2\x07")

输出是:2018,这就是我想要的。 问题是我的十六进制数据在一个列表中,格式为:

asd = ['e2','07']

我的问题是有没有一种简单的方法来使用 unpack 而不带反斜杠 x?像这样:

unpack("<H","e207")

我知道这行不通,但我希望你能明白。

为了澄清,我知道我可以在列表中以b'\x11' 的形式获取数据,但随后它被解释为 ASCII,这是我不想要的,这就是我以我显示的格式使用它的原因。

【问题讨论】:

【参考方案1】:

您在文本对象中有十六进制编码的数据。因此,要返回原始十六进制字节,您可以解码文本字符串。请注意,这不是 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,)

【讨论】:

使用 codecs.decode() 会有任何 ascii 解释吗?因为在我的情况下,我有一个包含数百个十六进制字符串的巨大列表,我不希望它们在任何时候被解释 我不确定您所说的“ascii 解释”是什么意思。理想情况下,您应该找到错误地将二进制数据保存为文本数据的代码,并将该代码更改为首先只保存二进制数据。 我的意思是,如果我使用 print() 来显示十六进制数字,python 会显示它们已经在 ascii 中解释 只要都是0-9 a-f就没有关系了。

以上是关于python 3中的解包语法的主要内容,如果未能解决你的问题,请参考以下文章

Python中的解包用法

熊猫数据框python中的解包列表[重复]

Python中的*args和**kwargs理解

返回语句中的 Python 元组解包

fig, ax = plt.subplots() 中的解包如何为多个子图工作?

python的解包操作符*和**是如何使用的?