我试图在表格中删除可变大小的单元格。我得到维度不匹配多次尝试。这里是代码(德语,只是随机名称):
entwicklung = {{'Mueller', 'Schroeder', 'Kuehn'},...
{'Schulz', 'Wagner'}, ...
{'Wolf', 'Schwarz', 'Neumann'}};
vertrieb = {{'Braun', 'Zimmermann'},...
{'Krueger', 'Klein'},...
{{'Schaefer'}}};
geschfhrng = {{{'Hofmann'}},...
{'Lange', 'Schmidt'},...
{{'Peters'}}};
qualitaet = {{'Moeller', 'Kaiser'},...
{{'Jung'}},...
{'Friedrich', 'Baumann'}};
doku = {{'Albrecht', 'Winkler'},...
{'Stein', 'Vogt', 'Ziegler'},...
{{'Pfeifer'}}};
cellB5 = [entwicklung; vertrieb; geschfhrng; qualitaet; doku];
zeilenbeschriftung = ...
{'Entwicklung', 'Vertrieb', 'Geschaeftsfuehrung', 'Qualitaet', 'Dokumentation'};
spaltenbeschriftung = ...
{'FuenfJahre', 'ZehnJahre', 'FuenfzehnJahre'};
structE2 = cell2struct(cellB5, spaltenbeschriftung, 2);
tabelle7 = cell2table(struct2cell(structE2));
% tabelle7.Properties
spaltennamen = {'Entwicklung', 'Vertrieb', 'Geschaeftsfuehrung',...
'Qualitaet', 'Dokumentation'};
zeilennamen = {'FuenfJahre', 'ZehnJahre', 'FuenfzehnJahre'};
tabelle7.Properties.VariableNames = spaltennamen;
tabelle7.Properties.RowNames = zeilennamen;
现在我想取消嵌套表中的单元格:
Entwicklung Vertrieb Geschaeftsfuehrung Qualitaet Dokumentation
___________ __________ __________________ __________ _____________
FuenfJahre {1×3 cell} {1×2 cell} {1×1 cell} {1×2 cell} {1×2 cell}
ZehnJahre {1×2 cell} {1×2 cell} {1×2 cell} {1×1 cell} {1×3 cell}
FuenfzehnJahre {1×3 cell} {1×1 cell} {1×1 cell} {1×2 cell} {1×1 cell}
为所有行获取与此类似的内容:
Entwicklung Vertrieb Geschaeftsfuehrung Qualitaet Dokumentation
________________________________ __________ __________________ ________________________ _____________
FuenfzehnJahre 'Wolf' 'Schwarz' 'Neumann' {1×1 cell} {1×1 cell} 'Friedrich' 'Baumann' {1×1 cell}
这里的挑战是将1x1单元解压缩并与其他行连接。对于预分配问题,我试图找到单元格的最大值,并希望从此向量创建一个空表,然后用单行填充空表。无法让它发挥作用。
使用此代码:
%{
spaltennamen = {'Entwicklung', 'Vertrieb', 'Geschaeftsfuehrung',...
'Qualitaet', 'Dokumentation'};
zeilennamen = {'FuenfJahre', 'ZehnJahre', 'FuenfzehnJahre'};
%}
tabelle12 = tabelle7;
tabellentiefe = size(tabelle7, 1);
maxSpaltenGroessen = max(cellfun(@max, cellfun(@size, tabelle12{:, :},...
'UniformOutput', false)));
neueZeileLeer = arrayfun(@(x) cell(1, x), maxSpaltenGroessen,...
'UniformOutput', false);
neueTabelleLeerCell = repmat(neueZeileLeer, tabellentiefe, 1);
neueTabelleLeer = cell2table(neueTabelleLeerCell);
tabelle12 = neueTabelleLeer;
tabelle12.Properties.VariableNames = spaltennamen;
tabelle12.Properties.RowNames = zeilennamen;
我明白了:
Entwicklung Vertrieb Geschaeftsfuehrung Qualitaet Dokumentation
______________ ______________ __________________ _________ _____________
FuenfJahre [] [] [] [] [] [] [] [] [] [] [] []
ZehnJahre [] [] [] [] [] [] [] [] [] [] [] []
FuenfzehnJahre [] [] [] [] [] [] [] [] [] [] [] []
现在我想将一个表“tabelle7”的内容转移到另一个表“tabelle12”。有什么帮助吗?