首页 > 解决方案 > 如何将 HEX 字符串转换为浮点数(Little Endian)

问题描述

我刚刚学习了 Python (3.x),我被 HEX 字符串转换为浮点数所困。我有这个 HEX 字符串值: '0x22354942F31AFA42CE6A494311518A43082CAF437C6BD4C35F78FA433BF10F442A5222448D3D3544200749C438295C4468AF6E4406B4804450518A4423B0934450E99CC4' 我想把它变成浮点数。

我曾尝试使用此代码:

bs=bytes.fromhex(row[2:])
fmt = '<' + ('H' * (len(bs) // 2))
res=struct.unpack(fmt, bs)

它给了我结果13602.0,16969.0,6899.0,17146.0,27342.0,17225.0,20753.0,17290.0,11272.0,17327.0,27516.0,50132.0,30815.0,17402.0,61755.0,17423.0,21034.0,17442.0,15757.0,17461.0,1824.0,50249.0,10552.0,17500.0,44904.0,17518.0,46086.0,17536.0,20816.0,17546.0,45091.0,17555.0,59728.0,50332.0

检查后,我发现我目前拥有的代码是以 16 为基数的浮点数,而我需要以 32 为基数的代码(或者可能不是因为我不确定什么基数/格式),以预期50.3018875, 125.052635,201.4172,276.633331,350.344,424.839722,500.9404,575.7692,649.2838,724.961731,804.1113,880.644043,954.7407,1029.62573,106.541,1181.50427,1255.291的浮点结果作为值我从这个计算器转换器得到的。我应该在编码中进行哪些更改以获得预期的结果?谢谢你。

标签: pythonpython-3.xfloating-pointtype-conversion

解决方案


让我们在这里分解一下,因为您似乎对所有表示的杂耍有点困惑。您有一些二进制数据的十六进制字符串(即基于 16 的编码)。那是你的0x22354942F31AFA42CE6A494311...。您正确地确定可以使用以下命令将其从编码形式转换为bytespython bytes.fromhex

hex_encoded = '0x22354942F31AFA42CE6A494311518A43082CAF437C6BD4C35F78FA433BF10F442A5222448D3D3544200749C438295C4468AF6E4406B4804450518A4423B0934450E99CC4'
binary_data = bytes.fromhex(hex_encoded[2:])  # we do 2: to remove the leading '0x'

在这一点上,除非我们知道是如何binary_data构造的,否则我们什么也做不了。但我们可以做一些猜测。您知道前几个数字是浮点数:50.3018875, 125.052635, 201.4172, .... 通常使用IEEE 754 标准对浮点数进行编码。这提供了 3 种不同的浮点数编码:binary16(16 位)、float(32 位)和 double(64 位)。您可以在struct 文档中看到这些,它们分别是格式代码'e''f''d'。我们可以尝试每个来查看您的二进制数据被编码为哪个(如果有)。通过反复试验,我们发现您的数据被编码为 32 位浮点数,因此您可以使用以下方法对其进行解码:

FLOAT = 'f'
fmt = '<' + FLOAT * (len(binary_data) // struct.calcsize(FLOAT))
numbers = struct.unpack(fmt, binary_data)
print(numbers)

为什么您尝试的方法不起作用?好吧,您使用了'H'无符号短格式的格式代码。这是一个整数,这就是为什么你得到没有小数部分的数字!


推荐阅读