@ UnbearableLightness имеет самое простое решение, но для пояснения предложения structured array
я приведу пример.
Определим структурированный массив:
In [192]: arr = np.array([(0.5,'one'),(0.6,'two'),(0.8,'three')], dtype=[('field1',float),('field2','U10')])
и список словари с одинаковыми полями и данными:
In [194]: dicts = [{'field1':0.5, 'field2':'one'},{'field1':0.6, 'field2':'two'},{'field1':0.8,'field2':'three'}]
In [195]: arr
Out[195]:
array([(0.5, 'one'), (0.6, 'two'), (0.8, 'three')],
dtype=[('field1', '<f8'), ('field2', '<U10')])
In [196]: dicts
Out[196]:
[{'field1': 0.5, 'field2': 'one'},
{'field1': 0.6, 'field2': 'two'},
{'field1': 0.8, 'field2': 'three'}]
сохранить и загрузить:
In [197]: io.savemat('ones.mat', {'arr':arr, 'dicts':dicts})
In [198]: io.loadmat('ones.mat')
Out[198]:
{'__header__': b'MATLAB 5.0 MAT-file Platform: posix, Created on: Fri May 1 09:06:19 2020',
'__version__': '1.0',
'__globals__': [],
'arr': array([[(array([[0.5]]), array(['one'], dtype='<U3')),
(array([[0.6]]), array(['two'], dtype='<U3')),
(array([[0.8]]), array(['three'], dtype='<U5'))]],
dtype=[('field1', 'O'), ('field2', 'O')]),
'dicts': array([[array([[(array([[0.5]]), array(['one'], dtype='<U3'))]],
dtype=[('field1', 'O'), ('field2', 'O')]),
array([[(array([[0.6]]), array(['two'], dtype='<U3'))]],
dtype=[('field1', 'O'), ('field2', 'O')]),
array([[(array([[0.8]]), array(['three'], dtype='<U5'))]],
dtype=[('field1', 'O'), ('field2', 'O')])]], dtype=object)}
savemat
создал несколько массивов dtype объектов (и полей) и массивы 2d MATLAB.
В октавном сеансе:
>> load ones.mat
arr
- это struct array
с 2 полями:
>> arr
arr =
1x3 struct array containing the fields:
field1
field2
>> arr.field1
ans = 0.50000
ans = 0.60000
ans = 0.80000
>> arr.field2
ans = one
ans = two
ans = three
dicts
- это ячейка со скалярными структурами :
>> dicts
dicts =
{
[1,1] =
scalar structure containing the fields:
field1 = 0.50000
field2 = one
[1,2] =
scalar structure containing the fields:
field1 = 0.60000
field2 = two
[1,3] =
scalar structure containing the fields:
field1 = 0.80000
field2 = three
}
, который может быть преобразован в тот же массив структуры, который показал @Unbearable:
>> [dicts{:}]
ans =
1x3 struct array containing the fields:
field1
field2
>> _.field1
error: '_' undefined near line 1 column 1
>> [dicts{:}].field1
ans = 0.50000
ans = 0.60000
ans = 0.80000
>> [dicts{:}].field2
ans = one
ans = two
ans = three