2

所以我有一个已读入列表的 CSV 文件。我已将该列表转换为数组,并将该数组保存到具有以下函数的 MATLAB 文件中。

def save_array(arr,filename):
    import scipy.io
    out_dict={}
    out_dict[filename]=arr
    scipy.io.savemat(filename + '.mat',out_dict)

但是,当我打开 MATLAB 文件时,出现了问题。当我在 Python 中打开时,我得到以下输出:

{'M': array([[u'153  ', u'81   ', u'0.28 ', ..., u'0.19 ', u'-0.07', u'1    '],
   [u'168  ', u'76   ', u'0.08 ', ..., u'0.98 ', u'0.42 ', u'0    '],
   [u'184  ', u'92   ', u'0.18 ', ..., u'0.92 ', u'0.75 ', u'0    '],
   ..., 
   [u'183  ', u'62   ', u'0.57 ', ..., u'0.87 ', u'0.31 ', u'0    '],
   [u'181  ', u'72   ', u'0.48 ', ..., u'0.91 ', u'1.2  ', u'0    '],
   [u'158  ', u'77   ', u'1.01 ', ..., u'0.99 ', u'0.88 ', u'0    ']], 
  dtype='<U5'),
 '__globals__': [],
 '__header__': 'MATLAB 5.0 MAT-file Platform: posix, Created on: Tue Nov  5 15:28:57 2013',
 '__version__': '1.0'}

为什么u每个元素的开头都有a?我该如何纠正这个问题?

4

1 回答 1

3

我看到您正在读取 CSV 文件并获取字符串数组。您可以在保存它们之前将它们转换为浮点数数组:

import numpy as np
out_dict[filename]=np.array(arr, dtype=np.float64)
于 2013-11-05T20:50:04.317 回答