1

我想在 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] 时,我得到相同的结果。):

[[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']

有谁知道问题是什么?

4

1 回答 1

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']
于 2018-01-03T16:26:56.750 回答