- "If the contents of the cells in a column of C have compatible sizes and types, then the corresponding table variable is the vertical concatenation of those contents into an array."
- "If the contents of the cells in a column have different sizes and types, then the corresponding table variable is a cell array."
Inconsistent type following cell2table
11 次查看(过去 30 天)
显示 更早的评论
Converting cell array with cell2table results in inconsistent conversion of arrays depending on (as far as I can tell) other members of the table column. Unfortunately this is causing issues for me, is there any simple fix that does not require changing inputs on a case-by-case basis?
MRE:
test = {[1, 2], [nan]; [nan], [nan]; [nan], [nan]};
test_table = cell2table(test);
test_table{2, 1}{1}; % okay (returns nan)
test_table{2, 2}{1}; % error: Brace indexing is not supported for variables of this type.
2 个评论
Stephen23
2022-5-3
"Converting cell array with cell2table results in inconsistent conversion of arrays depending on (as far as I can tell) other members of the table column."
Your 1st column will be a cell array (because [1,2] cannot be concatenated vertically with NaN), and because scalar NaNs can be concatenated the 2nd column will be numeric. Lets now check with your example data:
C = {[1,2],nan;nan,nan;nan,nan}
T = cell2table(C)
So far eveything seems to be working exactly as documented and as expected.
What do you expect the 1st column to be?
What do you expect the 2nd column to be?
采纳的回答
Star Strider
2022-5-3
Use parentheses, not curly braces, to index into a vector within a cell —
test = {[1, 2], [nan]; [nan], [nan]; [nan], [nan]};
test_table = cell2table(test)
test_table{2, 1}(1) % okay (returns nan)
test_table{2, 2}(1) % error: Brace indexing is not supported for variables of this type.
test_table{1,1}
test_table{1,1}{1}(1)
test_table{1,1}{1}(2)
The indexing can get a bit complicated.
.
3 个评论
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Logical 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!