Appending a table to another index error
    4 views (last 30 days)
  
       Show older comments
    
Hi all
I am appending a table to another one during a loop, every time I calculate the first one in each cycle.
this is the error I get 
Subscripting into a table using one subscript (as in t(i)) or three or more subscripts (as in t(i,j,k)) is not supported. Always specify a row subscript and a variable subscript, as in t(rows,vars).
Elapsed time is 21.683230 seconds.
and this is my code :
                        fn = cell2table(Tc, 'VariableNames', table_without_header.Properties.VariableNames);
                        if f1==1
                            Tout{1}=[fn];
                        else
                            Tout{f1} = [Tout{f1-1};fn];
                        end
fn is a 9x1 table and I think after the first loop, that also Tout becomes a 9x11 table I get this problem. how to resolve it ?
Accepted Answer
  Cris LaPierre
    
      
 on 9 Nov 2020
        
      Edited: Cris LaPierre
    
      
 on 9 Nov 2020
  
      The error explains the issue. You have to specify row and column. Try this (untested):
if f1==1
    Tout{1,:}=[fn];
else    
    Tout{f1,:} = [Tout{f1-1,:};fn];
end
Unless it was a typo, there appears to be an issue with the number of columns in fn (9x1) and Tout (9x11). They will both have to have the same number of columns for this code to work.
1 Comment
  Peter Perkins
    
 on 20 Nov 2020
				This code might run (although I don't think it will), but it seems hard to imagine that this is what you want. You say that "fn is a 9x1 table", and then "Tout becomes a 9x11 table". So how can a 9x1 table be stored in one row of another table? And why is each row of Tout apparently supposed to be an incrementally growing table?
This can't be right.
Are you trying to store each new instance of fn in a cell of a cell array? Or trying to concatenate all the tables vertically? I imagine if it's the latter, you want something more like
Tout = [Tout; fn]
at each iteration of your loop, but you haven't even shown any code with a loop in it.
More Answers (0)
See Also
Categories
				Find more on Loops and Conditional Statements in Help Center and File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

