0

我正在尝试读取包含多个不同(但已知)大小的数组的文本文件。

我知道有关文件的以下内容:

每个文件都有一个大小为 mxn 的矩阵,格式如下例所示:

[[0.05,0.15,0.25,0.35,0.0]
[0.05,0.1,0.15,0.2,0.25],
[0.05,0.1,0.15,0.2,0.25],
[0.05,0.1,0.5,0.6,0.1]]

接下来是一个大小为 px 1 的矩阵:

[3,3,4,5,5,5,5,6]

最后是一个标量(这里没有方括号)

3

我发现执行此操作的最简单方法如下:

  1. 从文本文件中去掉括号(使用比 MATLAB 更合适的语言!)
  2. 用于data = importdata()读取文件。这会产生一个数组,最后两行包含 px 1 矩阵和标量(由于矩阵大小之间的差异,有一些 NaN)
  3. 拉出数据,A = data(1:m, 1:n); b = data(m+1,1:p); c = data(m+2,1);

这似乎很笨拙。我可以将二维矩阵(包括括号)复制并粘贴到 MATLAB 命令窗口中,并且 MATLAB 知道如何解析它。这让我觉得有一种更优雅的方法可以用一个 MATLAB 函数来做到这一点。

整个示例文本文件:

[[0.05,0.15,0.25,0.35,0.0],
[0.05,0.1,0.15,0.2,0.25],
[0.05,0.1,0.15,0.2,0.25],
[0.05,0.1,0.5,0.6,0.1]]
[3,3,4,5,5,5,5,6]
3
4

1 回答 1

3

如果您愿意将此文件的内容传递给eval命令,这似乎是最直接的方法:

 %Read in the full file as a string  (this is often easier than handling the file directly)
fid = fopen('somefile.txt');
str = fread(fid,inf,'uint8=>char')';
fclose(fid);

str = ['{' str '}'];  %Add braces, this will gather the arrays when evaluated.
data = eval(str);     %Evaluate

这让我有些“一定是错的”感觉有些痒痒,因为这是一种非常脆弱的数据处理方式。但对于有限的数据集,它应该足够好。

我的samefile.txt文件包含以下内容(注意我在第一行添加了 0):

[[0.05,0.15,0.25,0.35,0],
[0.05,0.1,0.15,0.2,0.25],
[0.05,0.1,0.15,0.2,0.25],
[0.05,0.1,0.5,0.6,0.1]]
[3,3,4,5,5,5,5,6]
3

运行上述内容后,我有一个data包含以下内容的变量:

>> data{1}
ans =
       0.05                      0.15                      0.25                      0.35                         0
       0.05                       0.1                      0.15                       0.2                      0.25
       0.05                       0.1                      0.15                       0.2                      0.25
       0.05                       0.1                       0.5                       0.6                       0.1    
>> data{2}
ans =
   3     3     4     5     5     5     5     6
>> data{3}
ans =
   3
于 2013-10-24T22:52:24.653 回答