Convert a Cell array to a timetable
    6 Ansichten (letzte 30 Tage)
  
       Ältere Kommentare anzeigen
    
    CSCh
 am 26 Nov. 2024
  
    
    
    
    
    Verschoben: Steven Lord
    
      
 am 29 Nov. 2024
            Hi, I have 
A1=1x78995 cell array;
cell array {1x1800 double} {1x1800 double}.....
And A2 1x78995 cell with datetimes.
How can a create a timetable like
Time=timetable( [A2{1:78995}]',[78995x the first value of1800]'......,[78995x the last value of 1800])
 so that I have a timetabel of 78995x1801 at the end.
Thank you.
1 Kommentar
Akzeptierte Antwort
  Steven Lord
    
      
 am 26 Nov. 2024
        If you have a set of row vectors in a cell array
sampleCell = {1:10, 11:20, 21:30};
first to accomplish your stated goal you need to transpose them into column vectors. 
sampleCellTransposed = cellfun(@transpose, sampleCell, UniformOutput=false);
Then pass them into the table or timetable function as a comma-separated list.
T = table(sampleCellTransposed{:})
To make a timetable, of course one of the inputs must contain time-based data. In this case since none of the cells in sampleCellTransposed do, I pass it in as the first input argument.
dt = datetime('today')+(0:9).';
TT = timetable(dt, sampleCellTransposed{:})
1 Kommentar
Weitere Antworten (0)
Siehe auch
Kategorien
				Mehr zu Logical finden Sie in Help Center und File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


