Is there a way to append all arrays nested in a table without looping?
조회 수: 24 (최근 30일)
이전 댓글 표시
Hello all,
I have a matlab table t with a column d of arrays as shown below. Is there a way to concatenate all the arrays in d to a new variable say D without looping through the array? I am avoiding looping because it is so slow.
Thanks and regards.
![](https://www.mathworks.com/matlabcentral/answers/uploaded_files/1359693/image.png)
댓글 수: 2
Dyuman Joshi
2023년 4월 18일
How do you want to concatenate them? Horizontally? Vertically? Or otherwise?
Stephen23
2023년 9월 12일
The variable/column D must be a cell array inside that table, so you can simply use a comma-separated list:
For example, where T is your table:
D = horzcat(T.d{:})
D = vertcat(T.d{:})
답변 (2개)
Rik
2023년 4월 18일
Something like this should work:
t = table({19;17},{rand(100,1);rand(100,1)},'VariableNames',{'Umean','d'})
D=cell2mat(t.d);
size(D),class(D)
댓글 수: 2
Rik
2023년 4월 18일
Can you post example code that generates a similar variable? I showed you an example, and as you can see, that way it is easy to show you what to do.
I expect cell2mat complains, since you must have already tried it. You can also use vertcat:
tmp = t.i;
D = vertcat(tmp{:});
KSSV
2023년 4월 18일
D = table2array(T.d)
댓글 수: 3
Stephen23
2023년 4월 18일
편집: Stephen23
2023년 4월 18일
"T.d directly results in vertical concatenation if the data is numeric (which it looks like is the case in OP's data)"
To get 100x1 numeric data in one row requires nesting the numeric data inside a cell array. In the Workspace Viewer this is displayed without the curly braces, exactly as the OP's screenshot shows.
Your example creates 1x100 numeric vectors in each row, not 100x1 vectors like the OP.
Dyuman Joshi
2023년 4월 18일
Stephen, I am aware that my example creates 1x100 numeric vectors, which is what I mentioned in my comment as well.
"In the Workspace Viewer this is displayed without the curly braces"
I overlooked this. I will delete my above comment.
참고 항목
카테고리
Help Center 및 File Exchange에서 Logical에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!