Trouble reading 6 excel files (with multiple sheets) and storing each excel as a its own matrix with my loop.
    2 views (last 30 days)
  
       Show older comments
    
Here is my current code
%My Code
foldername = 'My Folder Path';
files = dir(fullfile(foldername, '*.xlsx'))
for i = 1:length(files)
  data = xlsread(fullfile(foldername,files(i).name));
end
This code works in some respect, however data only seems to hold 1 sheet from 1 excel file, despite the files variable having all 6 files in a 6x1 struct.
Ideally what I would like is 6 separate variables (or one that stores all six files, where I can reference specific files) in my workspace.
Then, I want to be able to reference data{sheets{columns/rows across every sheet}}. I believe I can do this part, its more so getting past the hurdle of importing each excel file.
Hope that makes sense and someone can offer some advice. Thank you.
1 Comment
  Elias Gule
      
 on 29 Mar 2018
				you are overwriting the values stored in the variable "data" in that for loop. So the data stored in the variable will be from the last file that was processed.
Answers (2)
  Elias Gule
      
 on 29 Mar 2018
        Doing this might help: Replacing
    data = xlsread(fullfile(foldername,files(i).name));
with
data{i} = xlsread(fullfile(foldername,files(i).name));
where data{i} contains data from the ith file.
  Elias Gule
      
 on 29 Mar 2018
        ok, lets do this then:
foldername = 'My Folder Path';
files = dir(fullfile(foldername, '*.xlsx'))
for i = 1:length(files)
   xldata = xlsread(fullfile(foldername,files(i).name));
   data{i}  = xldata;
end
See Also
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!
