Replace table elements in more than one row
이전 댓글 표시
Hi,
I have outputted a vector (V) which contains the row indices of elements in a table (T) that contain the string 'rpm'.
T has 3 columns and I initially set all of the elements in column 3 to zero. I now wish to replace all elements in column 3 that have these row indices (so only row 3 and row 7) with a value of 6. I have tried doing this but it doesn't work:
V = [3;7]; % row indices
for i = 1:numel(V)
T(V(i), 3) = repmat(6, numel(V), 1);
end
I get an error saying To assign to or create a variable in a table, the number of rows must match the height of the
table.
Thank you
댓글 수: 1
T = table(zeros(7,1),zeros(7,1),zeros(7,1),zeros(7,1)) % your table
V = [3;7]; % row indices
T(V, 3) = [repmat({6},numel(V),1)] % put the element in cell array when assigning
채택된 답변
추가 답변 (1개)
You can, but the code you wrote is trying to replace a single element with a vector, hence the error message.
When you are trying to replace each element with the same value, you do not need to use repmat. Perhaps you are trying to do this?
tb = table(zeros(4,1))
tb.Var1([1 3]) = 6
% you could also use repmat if you want
tb.Var1([2 4]) = repmat(10,2,1)
카테고리
도움말 센터 및 File Exchange에서 Data Type Identification에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!