我有一个包含 8000 个粒子位置的二进制文件。
我知道每个粒子值应该看起来像“-24.6151...”(我不知道我的程序给出的值的精度。我猜它是双精度(?)。
但是当我尝试使用以下代码读取文件时:
In: with open('.//results0epsilon/energybinary/energy_00004.dat', 'br') as f:
buffer = f.read()
print ("Lenght of buffer is %d" % len(buffer))
for i in buffer:
print(int(i))
我得到的输出:
Lenght of buffer is 64000
10
168
179
43
...
我跳过了整个值列表,但正如您所看到的,这些值与我的预期相距甚远。我想我有某种解码错误。
我将不胜感激任何形式的帮助:)
您现在打印的是bytes
编写浮点数据。所以它作为数值没有意义。
当然,由于我们没有看到您的数据,所以没有 100% 确定的答案,但我会尝试猜测:
您有 8000 个值要读取,文件大小为 64000。所以您可能有double
IEEE 值(每个 8 字节)。如果它是notIEEE,那么你就完蛋了。
在这种情况下,您可以尝试以下操作:
import struct
with open('.//results0epsilon/energybinary/energy_00004.dat', 'br') as f:
buffer = f.read()
print ("Length of buffer is %d" % len(buffer))
data = struct.unpack("=8000d",buffer)
如果打印的数据是伪造的,则可能是字节序问题。所以改变=8000
by <8000
or >8000
.
供参考和打包/拆包格式:https://docs.python.org/3/library/struct.html https://docs.python.org/3/library/struct.html
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)