Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/339.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
获得;bits";Python中的float?_Python_Floating Point_Bitwise Operators - Fatal编程技术网

获得;bits";Python中的float?

获得;bits";Python中的float?,python,floating-point,bitwise-operators,Python,Floating Point,Bitwise Operators,我正在寻找与Java的Float.floatToBits相当的Python 我发现了这个问题,但有人知道一个不那么复杂的方法吗?亚历克斯·马泰利在这个问题上给出的答案非常简单——你可以把它简化为: >>> import struct >>> >>> >>> def floatToBits(f): ... s = struct.pack('>f', f) ... return struct.unpac

我正在寻找与Java的
Float.floatToBits
相当的Python


我发现了这个问题,但有人知道一个不那么复杂的方法吗?

亚历克斯·马泰利在这个问题上给出的答案非常简单——你可以把它简化为:

>>> import struct
>>> 
>>> 
>>> def floatToBits(f):
...     s = struct.pack('>f', f)
...     return struct.unpack('>l', s)[0]
...     
... 
>>> floatToBits(173.3125)
1127043072
>>> hex(_)
'0x432d5000'
一旦将其作为整数,就可以执行需要的任何其他操作

您可以将操作顺序反转为往返:

>>> def bitsToFloat(b):
...     s = struct.pack('>l', b)
...     return struct.unpack('>f', s)[0]

>>> bitsToFloat(0x432d5000)
173.3125

下面是python float1的64位小尾端表示形式,只是为了补充讨论:

>>> import struct
>>> import binascii
>>> print('0x' + binascii.hexlify(struct.pack('<d', 123.456789)))
0x0b0bee073cdd5e40
导入结构 >>>导入binascii >>>打印('0x'+binascii.hexlify(struct.pack)('code>>>导入ctypes >>>f=c型浮点数(173.3125) >>>ctypes.c_int.from_address(ctypes.addressof(f)).value 1127043072
我不认为有必要强制使用big-endian。使用“=”有问题吗?谢谢。还有,我该如何做相反的事情:
Float.BitsToFloat
?我不会太依赖于这个断言。用
startVal=123.456
试试。是的,这很好,我喜欢对人们大喊大叫关于浮点数的平等性测试。我很抱歉我会删除它。我喜欢它,但是有什么不涉及字符串转换的吗?我经常通过分析发现,字符串是代码运行时间最长的部分。我该如何做相反的事情:
Float.BitsToFloat