在Python 3中,struct 模块允许我们使用 C 结构体格式化字符串处理二进制数据。
打包数据
data_tuple = (258, 3, 1.5)
format_string = '<hif'
packed_data = struct.pack(format_string, *data_tuple)
print("打包后的二进制数据:", packed_data)
输出:打包后的二进制数据: b’\x02\x01\x03\x00\x00\x00\x00\x00\xc0?’
在 struct 模块的格式化字符串中,字节序标识符可以有以下几种取值:
- < 表示小端字节序(little-endian)。
- > 表示大端字节序(big-endian)。
- ! 表示网络字节序(network byte order),它通常与大端字节序相同。
- 如果不指定字节序,struct 模块默认使用本地字节序,即计算机硬件的字节序。在网络通信中,经常使用大端字节序,因此可以使用 > 或者 ! 指定网络字节序,以确保数据的正确解析。
所以,<hif 中的 < 表示使用小端字节序,h 表示一个16位整数,i 表示一个32位整数,f 表示一个浮点数。
解包数据
逆向操作就是:
unpacked_data = struct.unpack('<hif', packed_data)
short_int_value = unpacked_data[0] # 获取16位整数的值
int_value = unpacked_data[1] # 获取32位整数的值
float_value = unpacked_data[2] # 获取浮点数的值
输出如下:
>>> print(unpacked_data)
(258


1933

被折叠的 条评论
为什么被折叠?



