Populate cell array dynamically
Show older comments
I have data output into a text file from which I can determine, for example, the following:
ssnname =
3×1 cell array
{'D1S02'}
{'D3S11'}
{'D3S12'}
ssnend =
10
20
24
What ssnname means is that the user has selected session2 from day1, session11 from day3, etc, and exported all the runs from those sessions into the text file, which I am analysing with MATLAB. What ssnend means is that after a readtable import of the text file, D1S02 data occupies the first 10 rows, D13S11 the next 10 rows, and D3S12 the final 4 rows, for a total of 24 runs exported by the user. What I'm trying to do is create a new nx1 (in this case, 24x1) cell array that contains 'D1S02' in the the first 10 values, 'D3S11' in the next 10, and 'D3S12' in the remaining 4, so that I can concatenate it into the table for plotting purposes.
This is done easily enough for a single case, but I'm trying to write code that will do it dynamically, regardless of how many sessions the user exports. As a point of info, ssnname and ssnend will always have the same number of values (rows), but the sessions themselves could contain any number of runs.
Vectorized or not, I could really use some help on this one. Thank you!
Accepted Answer
More Answers (1)
Image Analyst
on 24 Jun 2018
You say that after opening up one file, in a loop I guess, you "exported all the runs from those sessions into the text file" so just put them into a cell array at that point.
ca{cellIndex} = allRowsFromThisFile;
4 Comments
Rob Miller
on 24 Jun 2018
Image Analyst
on 24 Jun 2018
You'll note that my code simply puts your data into a cell array. It does not write anything to a file. You can put it in the loop were you were writing the data to a file but you can of course just omit the file writing part you did, and just keep the cell array storing part that I did.
Rob Miller
on 24 Jun 2018
Paolo
on 24 Jun 2018
@Rob does my solution not work for you?
Categories
Find more on Logical 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!