Problem with converting uitable to table (array2table) with strange number of column names

조회 수: 3 (최근 30일)
Hello, I have a UITable that on startup has 4 columns.
I want to create some dummy data (3 columns) and play with the different save options (writecell, writematrix and writetable) to see which one handles NaNs the best and can save the column names.
I am hence steering towards writetable.
However, when I clear the table and re-enter my dummy data via:
uit=app.UITable;
uit.Data=[];
r = randi([0,10],10,3)
uit.Data = [r];
I notice that the number of column names is still 4 and not 3, yet the data size in columns is 3!
T=app.UITable;
vn=T.ColumnName
vn = %UITable Column Names
4×1 cell array
{'Column 1'}
{'Column 2'}
{'Column 3'}
{'Column 4'}
ans = % UITable Data size
10 3
hence the following fails
T = array2table(data, 'VariableNames',vn')
Error using array2table
The VariableNames property must contain one name for each variable in the table.
Any suggestions please?
(and a 2nd question, most of the time my data is doubles, however occasionally its a cell array - when I want e.g. some text. I assume the only chnage I would need is when creating the table I would use cell2table instead of array2table?)
  댓글 수: 1
Voss
Voss 2025년 1월 25일
"... when I clear the table and re-enter my dummy data ... Any suggestions please?"
My suggestion would be to update ColumnName whenever necessary, including when the number of columns of Data changes.

댓글을 달려면 로그인하십시오.

채택된 답변

Jason
Jason 2025년 1월 25일
편집: Jason 2025년 1월 25일
This seems to work, but is quite a lot for such a simple task
T=app.UITable;
vn=T.ColumnName;
vn=vn' %Transpose so horizontal
data=T.Data;
[row,cols]=size(data);
[sy,nnames]=size(vn)
val=nnames-cols;
vn2=vn;
switch true
case val<0
ReportMessage(app,'less than zero, need less Vn')
n=abs(val) % number of headings less than data cols
vn2=vn(1:nnames);
for i=1:n
vn2(end+i)={'NA'}
end
case val>0
ReportMessage(app,'Greater than zero - need more vn')
vn2=vn(1:cols);
end
T = array2table(data, 'VariableNames',vn2)
  댓글 수: 6

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Tables에 대해 자세히 알아보기

제품


릴리스

R2023b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by