Какой самый быстрый способ создать, заполнить и раскрасить по очереди таблицу MS Word поверх ActiveX -> VBA (в моем конкретном случае я делаю это через MATLAB)?
Прямо сейчас я использую это следующим образом
hdlActiveX = actxserver('Word.Application');
...
hdlActiveX.ActiveDocument.Tables.Add(hdlActiveX.Selection.Range, nbRows, nbCols, 1, 1).Rows.Alignment = 1;
...
% create dataCell{nbRows, nbCols} containing the table values row- and columnwise
...
nrTable = ... % an integer selecting a table in the MS Word document
...
for r = 1:nbRows
for c = 1:nbCols
% Write data into current cell
hdlActiveX.ActiveDocument.Tables.Item(1).Cell(r,c).Range.Text = dataCell{r, c};
% setting a different background color rowwise, if a condtion is met
% this is even bigger performance reducer
if condition
for iCol = 1:nbCols
hdlActiveX.ActiveDocument.Tables.Item(nrTable).Cell(r,iCol).Select;
hdlActiveX.Selection.Shading.BackgroundPatternColor = color;
end
end
end
end
но для заполнения, действительно, очень долго, особенно для раскрашивания таблицы MS Word (ActiveX) по строкам ... Итак, как можно улучшить производительность заполнения таблицы?
Заранее спасибо,