31

私が文字列を持っていると仮定します:

my_data = '\x00\x00\x80?\x00\x00\x00@\x00\x00@@\x00\x00\x80@'

どこで入手したかは関係ありませんが、具体的なものにするために、バイナリファイルから読み取ったと仮定します。

私の文字列は4(4バイト)のfloatのバイナリ表現であることを知っています。それらのfloatをnumpy配列として取得したいと思います。私にできること:

import struct
import numpy as np
tple = struct.unpack( '4f', my_data )
my_array = np.array( tple, dtype=np.float32 )

しかし、中間のタプルを作成するのはばかげているようです。中間タプルを作成せずにこの操作を実行する方法はありますか?

編集

また、文字列のエンディアンを指定できるように配列を作成できるようにしたいと思います。

4

2 に答える 2

45
>>> np.frombuffer(b'\x00\x00\x80?\x00\x00\x00@\x00\x00@@\x00\x00\x80@', dtype='<f4') # or dtype=np.dtype('<f4'), or np.float32 on a little-endian system (which most computers are these days)
array([ 1.,  2.,  3.,  4.], dtype=float32)

または、ビッグエンディアンが必要な場合:

>>> np.frombuffer(b'\x00\x00\x80?\x00\x00\x00@\x00\x00@@\x00\x00\x80@', dtype='>f4') # or dtype=np.dtype('>f4'), or np.float32  on a big-endian system
array([  4.60060299e-41,   8.96831017e-44,   2.30485571e-41,
         4.60074312e-41], dtype=float32)

bもちろん、Python3より前では必要ありません。

実際、バイナリファイルを使用してデータをロードしている場合は、文字列の使用手順をスキップして、。を使用してファイルから直接データをロードすることもできますnumpy.fromfile()

また、念のため、dtypeリファレンス:http://docs.scipy.org/doc/numpy/reference/arrays.dtypes.html

于 2012-08-01T13:19:31.063 に答える