If I want to import a Nastran Deck into a Python Array, in one fell swoop using numpy. How can I go about it? Where am I going wrong?
I have a file with only Grids in it
The dtype
specifies the layout of the binary data in memory. It doesn't define the format of text in a file.
Your data file has fixed-width fields. That is, each field uses eight characters, and there is no special delimiter character to separate the fields. You can read such a file using numpy.genfromtxt, by specifying the field widths in the delimiter
argument.
Here's an example in an ipython session. First, here's your sample file. (I edited the file to ensure that there are three spaces after the final 05
in the second and third lines, but this wasn't necessary.)
In [15]: !cat nastran_data.txt
$ MH Nodes
$2345678$2345678$2345678$2345678$2345678$2345678
GRID 25601 58.50002-57.749923.05
GRID 25602 58.81002-57.749923.05
Here's the data type of the array to be created by genfromtxt
. Note that the GN
field has type np.int64
, and the X
, Y
and Z
fields have type np.float64
.
In [16]: dt = np.dtype([('Grid', 'S8'), ('GN', np.int64), ('Prop', 'S8'), ('X', np.float64), ('Y', np.float64), ('Z', np.float64)])
Read the file using genfromtxt
, with six fixed-width fields, each of length 8:
In [18]: a = np.genfromtxt('nastran_data.txt', dtype=dt, delimiter=(8, 8, 8, 8, 8, 8), skip_header=2)
In [19]: a
Out[19]:
array([('GRID ', 25601, ' ', 58.50002, -57.7499, 23.05),
('GRID ', 25602, ' ', 58.81002, -57.7499, 23.05)],
dtype=[('Grid', 'S8'), ('GN', '