我的目标是加载表中列出的一些文件,提取数据,并将结果保存为第一个文件名的变量。表中的列表是用户输入字符,表示即将加载的文件的名称。我给你举个例子,因为你可能不明白我的意思。当表中列出 A,B,C(字符串)时,我的代码将找到它们的位置(例如 A.txt)并加载它们的数据。从它们收集数据后,结果以表的名称保存,如下所示:A(变量)= result_data(:4)。这是我的代码。请让我知道错误的地方。(请注意,该表是使用 uitable 的 nx1 单元格数组。
function pushbutton1_Callback(hObject, eventdata, handles)
data = get(handles.uitable,'data'); % get strings in table
for i = 1:size(data(:,1)) % count the #strings
fid = fopen([ data(i),'.csv' ]); %load the data and extract what I need
...
fclose(fid);
data(i) = result(row_1:row_2 , 4) % this is the result_data
% data(i) is variable string, so I am not sure whether to use the eval function.
结束
我的建议是没有您的表进一步调试。data
可能是一个单元格数组,因为您是从如下所示的uitable
中提取的。
data = get(handles.uitable,'data'); % get strings in table
所以这一行应该出错:
fid = fopen([ data(i),'.csv' ]);
将其更改为:
fid = fopen([ data{i},'.csv' ]);
或者这个:
fid = fopen([ char(data(i)),'.csv' ]);
将结果保存到与您的字符串匹配的变量名称时,我建议使用具有动态字段名称的结构而不是裸变量......否则,您可能不得不使用应避免使用的 eval。
所以这个(这不是你要求的):
data(i) = result(row_1:row_2 , 4) % this is the result_data
应该变成:
outData.(data{i}) = result(row_1:row_2 , 4) % this is the result_data
如果data
像你说的那样是一个包含{'A','B','C',...}的单元格数组 然后outData
将是下面的形式,并包含每个结果。
outData.A
outData.B
outData.C