如何解决struct.unpack 返回非常大的值 python
我觉得这应该很简单,因为它太简单了,我无法理解为什么它不起作用。
我有一个基本函数,它使用 struct.unpack 将字节数组转换为整数。所以我们可以看到十六进制表示法中的 x90 = 144 十进制。所以我希望如果我要求解包转换为整数,我会得到 144,但我得到的是这个大得离谱的数字。我很乐意阅读您能提供的任何参考资料,因为 struct documentation 没有提供任何线索。
见下面的例子:
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
解决方法
您正在解压缩值 0x90_00_00_00,即以小端顺序排列的 64 位数字。它很大,因为它有 7 个十六进制零,每个零代表 16 的幂。
要么颠倒字节顺序,要么pick a different byte order:
>>> 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,)
在上面的示例中,>
中的 '>I'
告诉 struct.unpack()
改用大端排序。如果您正在处理从某个网络协议接收到的数据,您可能应该使用 !
代替,它表示根据 IETF RFC 进行网络通信的默认字节顺序;这与 >
大端顺序相同,但进行了编码以避免混淆。
如果没有明确的字节顺序标记,则假定为 @
或 native 字节顺序。在您的特定情况下,您的机器本机字节顺序是小端字节序,但这是您计算机的特定机器架构的属性,而不是 Python 的属性。
格式 'i'
和 'I'
使用您机器的本机字节顺序,在这种情况下是小端字节序。您可以明确说明endianness you want to use。
>>> struct.unpack('i',b'\x00\x00\x00\x90') # native,implicit
(-1879048192,)
>>> struct.unpack('@i',explicit
(-1879048192,)
>>> struct.unpack('<i',b'\x00\x00\x00\x90') # explicitly little-endian
(-1879048192,)
>>> struct.unpack('>i',b'\x00\x00\x00\x90') # explicitly big-endian
(144,)
>>> struct.unpack('!i',b'\x00\x00\x00\x90') # explicitly network order
(144,)
网络协议使用 big-endian 作为独立于机器的排序。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。