struct.unpack返回非常大的值python
我觉得这应该很简单,因为它太简单了,我无法理解为什么它不起作用。
我有一个基本函数,它使用 struct.unpack 将字节数组转换为整数。所以我们可以看到十六进制表示法中的 x90 = 144 十进制。所以我希望如果我要求解包转换为整数,我会得到 144,但我得到的是这个大得离谱的数字。我很高兴阅读您可以提供的任何参考资料,因为结构文档没有提供任何线索。
请参阅下面的示例:
unpack_signed_integer, = struct.unpack('i', b'x00x00x00x90')
unpack_unsigned_integer, = struct.unpack('I', b'x00x00x00x90')
print(f"signed integer: {unpack_signed_integer}")
print(f"unsigned integer: {unpack_unsigned_integer}")
输出:
signed integer: -1879048192
unsigned integer: 2415919104
回答
您正在解压缩值 0x90_00_00_00,即以小端顺序排列的 64 位数字。它很大是因为它有 7 个十六进制零,每个零代表 16 的幂。
要么颠倒字节顺序,要么选择不同的字节顺序:
>>> import struct
>>> struct.unpack('I', b'x00x00x00x90')
(2415919104,)
>>> struct.unpack('I', b'x90x00x00x00')
(144,)
>>> struct.unpack('>I', b'x00x00x00x90')
(144,)
在上面的例子中,>in'>I'告诉struct.unpack()改用大端排序。如果您正在处理从某个网络协议接收到的数据,您可能应该!改用它,它表示根据IETF RFC 的网络通信的默认字节顺序;这与>大端顺序相同,但进行了编码以避免混淆。
假定没有显式字节顺序标记,@或本机字节顺序。在您的特定情况下,您的机器本机字节顺序是小端字节序,但这是您计算机的特定机器架构的属性,而不是 Python 的属性。