Routine that recall various files and apply a script

4 次查看(过去 30 天)
Hello everyone, I have a question. I wrote a simple script that analyse a xlsx file. I have many of these files in a single directory. Can someone recommend me a skeleton of a routine that automatically recall these files and apply the script at each file? Thank you very much.

采纳的回答

Walter Roberson
Walter Roberson 2016-11-22
projectdir = 'C:\Directory\Where\The\FilesAre';
dinfo = dir( fullfile( projectdir, '*.xlsx') );
filenames = fullfile( projectdir, {dinfo.name} );
for K = 1 : length(filenames)
thisfile = filenames{K};
[num, txt, raw] = xlsread(thisfile);
...
end
  2 个评论
Guglielmo Giambartolomei
Thank you Walter Roberson, but I'm too a beginner to understand your code. I appreciate anyway; thank you very much!
Walter Roberson
Walter Roberson 2016-11-23
projectdir = 'C:\Directory\Where\The\FilesAre';
cd(projectdir);
dinfo = dir( '*.xlsx' );
for K = 1 : length(dinfo)
thisfile = dinfo(K).name;
[num, txt, raw] = xlsread(thisfile);
...
end
dir() returns a structure array of information about the files it finds. You need to index that structure at an offset to find information for one file. One of the fields that is recorded for every file is "name", the name of the file. Pull that out of the structure and read the information from the file.

请先登录,再进行评论。

更多回答(1 个)

Jan
Jan 2016-11-21
This sounds like a frequently asked question. Then a search in the net should be successful. Et voila: FAQ: How can I process a sequence of files

类别

Help CenterFile Exchange 中查找有关 File Operations 的更多信息

标签

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by