how to set a range for xlsread command
Show older comments
I write a function to read all CSV files in my folder at once and and save all of them in one table. But I have problem regarding the xlsread command (ensemble data store).
I write my command in this way cell = xlsread(filename, 'H24:S1000'); and this command will be applied for all my CSV files in my folder. However my CSV files have different rows (some of them have more rows than 1000 rows and some of them have less).
Now what I need is to write my command in the way that be able to write this range "from column H row 24 to column S to last row" how should I set this range in my xlsread command.
Thanks for your help
Answers (1)
Fangjun Jiang
on 24 Jul 2018
Edited: Fangjun Jiang
on 24 Jul 2018
I would just read the whole sheet and then cut it in MATLAB
[~,~,RawData]=xlsread(filename);
UsefulData=RawData(8:19,24:end);
% 8 and 19 are corresponding to column H and S
char('A'+7)
char('A'+18)
use csvread()
UsefulData=csvread('filename.csv',23,7);
UserfulData(:,19:end)=[];
4 Comments
Sara
on 24 Jul 2018
Fangjun Jiang
on 24 Jul 2018
Edited: Fangjun Jiang
on 24 Jul 2018
Use csvread('filename.csv', R, C) where R and C are the starting row and column position (zero based), so in your case would be csvread('filename.csv',23,7) and then you can cut the columns after column S (see updated answer).
In either case, you will need a for-loop to read 200 files. All the temporary variables can be re-used so it won't take 200 times of the memory.
Sara
on 25 Jul 2018
first of all my data are too big and it is time consuming
Using xlsread to read csv data is always going to be very time consuming. dlmread, csvread or the more modern readtable (the latter sounding exactly like what you need) will all be significantly faster than xlsread.
xlsread delegates the parsing of the file to excel. The first thing matlab has to do is start excel (invisibly in the background) which takes a while. It's a complete waste of time when matlab is perfectly capable of reading the files itself.
Categories
Find more on Data Import from MATLAB 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!