使用Python实现浮点数与基于754标准的16进制之间的转换

我们需要使用内置struct库中的packunpack函数。

下面实现的有单精度和双精度的浮点数转换。

import struct
import numpy as np

def float_to_hex(f):
    return hex(struct.unpack('<I', struct.pack('<f', f))[0])

def hex_to_float(h):
    i = int(h,16)
    return struct.unpack('<f',struct.pack('<I', i))[0]

def double_to_hex(f):
    return hex(struct.unpack('<Q', struct.pack('<d', f))[0])

def hex_to_double(h):
    i = int(h,16)
    return struct.unpack('<d',struct.pack('<Q', i))[0]

if __name__ == '__main__':
    f1 = np.array([17.5,-17.5,77.3,-77.3],np.float32)
    f2 = np.array([17.5, -17.5, 77.3, -77.3], np.float64)
    h1 = []
    h2 = []
    for i in f1:
        print(float_to_hex(i))
        h1.append(float_to_hex(i))
    for i in h1 :
        print(hex_to_float(i))

    for i in f2:
        print(double_to_hex(i))
        h2.append(double_to_hex(i))
    for i in h2 :
        print(hex_to_double(i))

输出结果

0x418c0000
0xc18c0000
0x429a999a
0xc29a999a
17.5
-17.5
77.30000305175781
-77.30000305175781


0x4031800000000000
0xc031800000000000
0x4053533333333333
0xc053533333333333
17.5
-17.5
77.3
-77.3
posted @ 2020-11-28 19:30  耐心的小黑  阅读(874)  评论(0编辑  收藏  举报