我想在 parfor 循环之外(在代码的开头)创建 excel 文件,然后用每个循环更新 excel 文件,最后在循环完成后将 excel 文件存储到特定位置。但是我遇到了一些错误。使用以下命令:
matlabpool('open',2);
pwd='C:\Users\myPC\Desktop';
fName = fullfile(pwd, 'file.xls');
%# create Excel COM Server
Excel = actxserver('Excel.Application');
Excel.Visible = true;
%# create new XLS file
wb = Excel.Workbooks.Add();
wb.Sheets.Item(1).Activate();%line 10
offset = 0;
C1 = {'NAME', 'Max', 'Min','Average'};
%# calculate cell range to fit matrix (placed below previous one)
cellRange = xlcalcrange('A1', offset,0, size(C1,1),size(C1,2));
offset = offset + size(C1,1);
%# insert matrix in sheet
Excel.Range(cellRange).Select();
Excel.Selection.Value =C1;
parfor i=1:2
%some code , eg :
MAX =1
MIN =2
AVG=3
name='jpg'
row2 = { name MAX MIN AVG };
%# calculate cell range to fit matrix (placed below previous one)
cellRange = xlcalcrange('A1', offset,0, size(row2,1),size(row2,2));
offset = offset + size(row2,1);
Excel.Range(cellRange).Select(); %line32
Excel.Selection.Value =row2;
end
%# parsave XLS file
wb.SaveAs(fName,1);
wb.Close(false);
%# close Excel
Excel.Quit();
Excel.delete();
matlabpool('close');
上面的代码显示以下错误:1. parfor 中的变量 Excel 无法分类。, 2. 由于使用变量 'offset' 的方式,PARFOR 循环无法运行。, 3. PARFOR 循环无法运行,因为方式变量 'Excel' 被使用。,4. 'Excel' 的有效索引在 PARFOR 循环中受到限制。,5. 第 10 行调用被 callee.Error 拒绝(wb.Sheets.Item(1).Activate(); )。
Pls. help to use above code so that I can create excel file which updates inside PARFOR loop and EXCEL file get saved outside PARFOR loop