我想在python中读取matfile,然后将数据导出到数据库中。为了做到这一点,我需要在python中将数据类型作为列表。我写了下面的代码:
import scipy.io as si
import csv
a = si.loadmat('matfilename')
b = a['variable']
list1=b.tolist()
变量有1行和15列。当我打印list1
时,我得到以下答案:(它确实是一个列表,但是只包含一个元素的列表。这意味着当我调用list1 [0]时,我得到相同的结果。):< / p>
[[array(['A'],
dtype='<U13'), array(['B'],
dtype='<U14'), array(['C'],
dtype='<U6'), array(['D'],
dtype='<U4'), array(['E'],
dtype='<U10'), array(['F'],
dtype='<U13'), array(['G'],
dtype='<U11'), array(['H'],
dtype='<U9'), array(['I'],
dtype='<U16'), array(['J'],
dtype='<U18'), array(['K'],
dtype='<U16'), array(['L'],
dtype='<U16'), array(['M'],
dtype='<U16'), array(['N'],
dtype='<U14'), array(['O'],
dtype='<U13')]]
虽然我期望的形式是:
['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O']
有谁知道问题是什么?
答案 0 :(得分:0)
根据我的经验,这就像MATLAB文件是结构化的,只有嵌套数组。
您可以自己创建列表:
>>> [x[0][0] for x in list1[0]]
['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O']