如何将十六进制字符串转换为Float(小尾数法)

时间:2019-03-24 23:06:02

标签: python python-3.x floating-point type-conversion

我刚刚学习了Python(3.x),并且对将HEX String转换为Float感到困惑。我有这个十六进制字符串值: '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的价值,我从这个Calculator Converter获得的价值。 我应该在编码中进行哪些更改才能获得预期的结果? 谢谢。

1 个答案:

答案 0 :(得分:2)

让我们在这里分解一下,因为您似乎对所有表示形式的处理都有些困惑。您有一些二进制数据的十六进制字符串(以16为基数的编码)。那就是你的0x22354942F31AFA42CE6A494311...。您正确地确定可以使用bytes将其从其编码形式转换为python 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 standard进行编码。这提供了3种不同的浮点数编码:binary16(16位),float(32位)和double(64位)。您可以在struct documentation中看到它们,它们分别是格式代码'e''f''d'。我们可以尝试每种方法来查看您的二进制数据被编码为哪个(如果有)。通过反复试验,我们发现您的数据被编码为32位浮点数,因此您可以使用以下代码对其进行解码:

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

为什么您尝试的方法不起作用?好吧,您使用了格式代码'H',它是无符号的缩写。这是一个整数,这就是为什么您要取回没有小数部分的数字的原因!