组合四个字节并转换为浮点数

Posted

技术标签:

【中文标题】组合四个字节并转换为浮点数【英文标题】:combine four bytes and convert to float 【发布时间】:2014-08-28 22:25:29 【问题描述】:

我在我的问题上发现了许多其他主题,但没有一个与我想要的完全匹配,或者我很难重新调整用途。

我正在使用一个名为 smbus.read_byte() 的函数。根据文档,它返回很长。如果我打印它返回的内容,我会得到一个从 0 到 255 的数字。

我想做的是执行四次读取,然后结合这些信息来生成一个浮点数。所以 65、203、96、66 应该是 25.422。

有很多使用 struct 包的建议,但我有点困惑如何将结果组合成一个数字,然后将其转换为浮点数。

【问题讨论】:

【参考方案1】:
>>> data = [65, 203, 96, 66]
>>> b = ''.join(chr(i) for i in data)
>>> import struct
>>> struct.unpack('>f', b)
(25.422000885009766,)

分解它,join 行将每个整数值转换为一个字符字节,然后将它们连接成一个字符串,这是struct.unpack 要求的输入。测试表明你的字节是大端顺序的,需要>格式为unpack

Python 3 区分了字符串和字节字符串,因此上面显示的join 不起作用。您可以使用 struct 而不是 join 将值组合成一个字节字符串,这在 Python 2 和 3 中都可以使用:

b = struct.pack('4B', *data)

【讨论】:

以上是关于组合四个字节并转换为浮点数的主要内容,如果未能解决你的问题,请参考以下文章

在 Swift 中将半精度浮点数(字节)转换为浮点数

将字节转换为浮点数?

将 24 位值转换为浮点数并返回

如何在java中将4字节数组转换为浮点数

怎么将4字节16进制转化成浮点数

将(n个第一个字节)无符号字符指针转换为浮点数和双精度C++