我想将一个二进制数转换成一个浮点数.这是一个可能性的例子:
>>> float(-0b1110)
给我正确的输出:
-14.0
不幸的是,我正在使用二进制字符串,即我需要像float(‘ – 0b1110’)这样的东西.但是,这不行:
>>> float('-0b1110') Traceback (most recent call last): File "<stdin>",line 1,in <module> ValueError: invalid literal for float(): -0b1110
我尝试使用* binascii.a2b_qp(string [,header])*,它将一个引用的可打印数据块转换回二进制,并返回二进制数据.但是最终我得到了同样的错误:
>>> float(binascii.a2b_qp('-0b1110')) Traceback (most recent call last): File "<stdin>",in <module> ValueError: invalid literal for float(): -0b1110
解决方法
float(int('-0b1110',0))
这对我行得通.
如果您有一个64位字符串表示浮点数而不是整数,则可以进行三步转换 – 第一步将字符串转换为整数,第二步将其转换为8字节字符串,第三个将这些位重新解释为浮点数.
>>> import struct >>> s = '0b0100000000101001000101111000110101001111110111110011101101100100' >>> q = int(s,0) >>> b8 = struct.pack('Q',q) >>> struct.unpack('d',b8)[0] 12.546
当然,您可以将所有步骤组合成一行.
>>> s2 = '0b1100000000101100000000000000000000000000000000000000000000000000' >>> struct.unpack('d',struct.pack('Q',int(s2,0)))[0] -14.0