从"无符号"字节流中读取32位有符号值

Nik*_*s R 4 python sign endianness

我想从一个文件中提取数据,该文件信息以big-endian存储,并且总是无符号的.从unsigned intint"强制转换"如何影响实际的十进制值?我是否纠正了最左边的位决定该值是正还是负?

我想用python解析该文件格式,并且读取和无符号值很容易:

def toU32(bits):
    return ord(bits[0]) << 24 | ord(bits[1]) << 16 | ord(bits[2]) << 8  | ord(bits[3])
Run Code Online (Sandbox Code Playgroud)

但相应的toS32功能会如何?


感谢有关struct -module 的信息.但我仍然对我的实际问题的解决方案感兴趣.

gri*_*eve 8

我会用struct.

import struct

def toU32(bits):
    return struct.unpack_from(">I", bits)[0]

def toS32(bits):
    return struct.unpack_from(">i", bits)[0]
Run Code Online (Sandbox Code Playgroud)

格式字符串"> I"表示从字符串位读取大端,">",无符号整数,"I".对于有符号整数,您可以使用"> i".

编辑

不得不看另一个StackOverflow 答案,记住如何从python中的无符号整数"转换"有符号整数.虽然它不是转换,而是更多地重新解释位.

import struct

def toU32(bits):
        return ord(bits[0]) << 24 | ord(bits[1]) << 16 | ord(bits[2]) << 8  | ord(bits[3])

def toS32(bits):
    candidate = toU32(bits);
    if (candidate >> 31): # is the sign bit set?
        return (-0x80000000 + (candidate & 0x7fffffff)) # "cast" it to signed
    return candidate


for x in range(-5,5):
    bits = struct.pack(">i", x)
    print toU32(bits)
    print toS32(bits)
Run Code Online (Sandbox Code Playgroud)