我有一个包含 3 个字节的字节流,我必须将其转换为无符号整数 32。在 CI 中,只需使用 bzero 将我的整数的内存区域清零,然后从流中复制内存,类似于
char* stream = ...;
Uint32 myInt;
bzero(myInt,4);
memcopy(myInt, stream[0], stream[3])
问题:
我将如何在 Python 中做到这一点?
干杯
即使在 C 语言中,您也不应该使用memcpy
二进制反序列化,因为它不处理二进制表示,即字节序、符号等。将二进制值从流中的固定表示显式解码为平台的本机表示。
在 Python 中,您将从流中读取字节,根据字节序填充它们,然后使用以下命令解压缩它们struct
:
chunk = fileobj.read(3)
# decode bytes as little-endian, signed integer
chunk += '\x00'
number = struct.unpack('<i', chunk)
fileobj
是一个类文件对象,代表打开的流,即用 . 打开的文件open(filename, 'rb')
。
你有没有尝试过:
myInt = (ord (myStr[0]) * 256 + ord (myStr[1])) * 256 + ord (myStr[2])
以下程序:
myStr = "abc"
myInt = ord (myStr[0]) * 65536 + ord (myStr[1]) * 256 + ord (myStr[2])
print myInt
6382179
按预期输出:
'a' (97) * 65536 = 6356992
'b' (98) * 256 = 25088
'c' (99) * 1 = 99
-------
6382179
当然,这是假设字符串采用大端格式。对于 little-endian,其中最重要的八位字节是字符串中的第三个,您可以反转字符串索引(2, 1, 0
而不是0, 1, 2
)。
正如@paxdiablo 所说,ord
这是解决方案。这是一个<<
使它更熟悉C的解决方案:
sum([ord(c) << 8 * i for i, c in enumerate(s) ])