python - 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
解决方案
您正在解压值 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 的属性。
推荐阅读
- mysql - 使用分组和 mySql 排序的输出
- git - 不能 git add 。在新仓库中暂存文件
- java - 在paintComponent中获取组件位置
- python - 如何将两个列表的所有组合拆分 N 倍?
- excel - 如何从前两个列中获取相同日期的列表,然后在新的 DataFrame 中获取第三个列的值?
- php - 无法使用 php7.0 将列添加到表中
- node.js - 当我尝试在 cmment 线上运行 gulp 时,gulp 4.0.0 显示错误
- sql - 在哪里可以找到“.NET CLR 内存”
- java - 如何在插入数据之前在 Java 中测试 SQL 字段类型
- css - 如何使图像出现在链接悬停