0

我想在 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
4

1 回答 1

0

从不同线程同时写入文件是不安全的。这就是当您尝试执行此类操作时 MATLAB 会自动出错的原因。

这个问题的答案将是以下两个之一:

  1. parfor循环内,将输出写入某种独立的缓冲区,然后在parfor循环外将缓冲区串行写入文件。或者,
  2. 不要使用parfor. 改为使用for

请参阅:http: //blogs.mathworks.com/loren/2009/10/02/using-parfor-loops-getting-up-and-running/了解有关parfor命令限制的更多信息。

于 2014-09-08T19:22:39.963 回答