Python Pandas Dataframe to Matlab Struct using Scipy.i

2024-10-05 15:24:06 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试使用scipy.io将pandas数据帧保存到一个matlab.mat文件中。

我有以下资料:

array1 = np.array([1,2,3])
array2 = np.array(['a','b','c'])
array3 = np.array([1.01,2.02,3.03])
df = DataFrame({1:array1, 2:array2,3:array3}, index=('array1','array2','array3'))
recarray_ = df.to_records()
## Produces:
# rec.array([('array1', 1, 'a', 1.01), ('array2', 2, 'b', 2.02),
#   ('array3', 3, 'c', 3.03)], 
#  dtype=[('index', 'O'), ('1', '<i4'), ('2', 'O'), ('3', '<f8')])
scipy.io.savemat('test_recarray_struct.mat', {'struct':df.to_records()})

在Matlab中,我希望它生成一个包含三个数组(一个int,一个char,一个float)的结构,但实际上它生成的是一个包含三个以上结构的结构,每个都包含四个变量:“index”,1,“2”,3。尝试选择1、2或3时,出现错误“变量结构(1、1)。”不存在

有人能解释一下预期的行为以及如何最好地将数据帧保存到.mat文件吗?


Tags: 文件to数据iodfindexnpscipy
2条回答

在此期间,我正在使用以下解决方法。如果你有更好的解决方案,请告诉我:

a_dict = {col_name : df[col_name].values for col_name in df.columns.values}

## optional if you want to save the index as an array as well:
# a_dict[df.index.name] = df.index.values
scipy.io.savemat('test_struct_to_mat.mat', {'struct':a_dict})

我认为您需要创建这样的数据帧:

df = DataFrame({'array1':array1, 'array2':array2,'array3':array3})

像这样保存:

scipy.io.savemat('test_recarray_struct.mat', {'struct':df.to_dict("list")})

所以代码应该是这样的:

# ... import appropritely
array1 = np.array([1,2,3])
array2 = np.array(['a','b','c'])
array3 = np.array([1.01,2.02,3.03])
df = DataFrame({'array1':array1, 'array2':array2,'array3':array3})
scipy.io.savemat('test_recarray_struct.mat', {'struct':df.to_dict("list")})

相关问题 更多 >