擅长:python、mysql、java
<p>我建议使用<a href="http://docs.python.org/library/ctypes.html" rel="noreferrer">the ctypes module</a>,它基本上允许您处理低级数据类型。在你的情况下你可以说</p>
<pre><code>from ctypes import *
def convert(s):
i = int(s, 16) # convert from hex to a Python int
cp = pointer(c_int(i)) # make this into a c integer
fp = cast(cp, POINTER(c_float)) # cast the int pointer to a float pointer
return fp.contents.value # dereference the pointer, get the float
print convert("41973333") # returns 1.88999996185302734375E1
print convert("41995C29") # returns 1.91700000762939453125E1
print convert("470FC614") # returns 3.6806078125E4
</code></pre>
<p>我相信<code>ctypes</code>模块在这里是有意义的,因为您实际上是在问如何执行低级位转换。基本上,您的问题是,我如何告诉Python获取一些数据并将这些数据解释为那些完全相同的位是不同的数据类型?</p>
<p>在C语言中,如果你有一个int,想把它的位解释成一个浮点,你可以做大致相同的事情,取一个指针,然后对其进行转换和解引用:</p>
<pre><code>int i = 0x41973333;
float f = *((float*)&i);
</code></pre>
<p>在我的示例中,使用<code>ctypes</code>库的Python代码正是这样做的。</p>