首页 > 解决方案 > struct.unpack 返回非常大的值 python

问题描述

我觉得这应该很简单,因为它很简单,我无法理解为什么它不起作用。

我有一个使用 struct.unpack 将字节数组转换为整数的基本函数。所以我们可以在十六进制表示法中看到 x90 = 十进制的 144。所以我希望如果我要求 unpack 转换为整数,我会得到 144,但我会得到这个大得离谱的数字。我很高兴阅读您可以提供的任何参考资料,因为struct 文档没有提供任何线索。

请参见下面的示例:

unpack_signed_integer, = struct.unpack('i', b'\x00\x00\x00\x90')
unpack_unsigned_integer, = struct.unpack('I', b'\x00\x00\x00\x90')

print(f"signed integer: {unpack_signed_integer}")
print(f"unsigned integer: {unpack_unsigned_integer}")

输出:

signed integer: -1879048192
unsigned integer: 2415919104

标签: pythonarrayspython-3.xstructunpack

解决方案


您正在解压值 0x90_00_00_00,即小端顺序的 64 位数字。它很大,因为它有 7 个十六进制零,每个零代表 16 的幂。

要么颠倒你的字节顺序,要么选择不同的字节顺序

>>> import struct
>>> struct.unpack('I', b'\x00\x00\x00\x90')
(2415919104,)
>>> struct.unpack('I', b'\x90\x00\x00\x00')
(144,)
>>> struct.unpack('>I', b'\x00\x00\x00\x90')
(144,)

在上面的例子中,>in'>I'告诉struct.unpack()使用 big-endian 排序。如果您正在处理从某个网络协议接收到的数据,您可能应该!改用它,它表示根据IETF RFC的网络通信的默认字节顺序;这与>大端顺序相同,但已编入代码以避免混淆。

假定没有明确的字节顺序标记,@本机字节顺序。在您的特定情况下,您的机器本机字节顺序是 little-endian,但这是您计算机的特定机器架构的属性,而不是 Python 的属性。


推荐阅读