Need to find files in a dir structure with similar but not identical names
이전 댓글 표시
I am trying to pull data from multiple files in a directory. I have written a for loop to get to the specified file, but when I search for the file using an * is cannot be found. For example, the file name 072814_Nominal.xls and another file in the same directory might be called 081213_Nominal.xls. I want to pull date from only files with "Nominal" in the name. I have tried using the below loop
D=dir(pathname);
for i=1:length(D)
if D(i).name=='*Nominal.xls' %this line is trouble - says matrix dimensions must agree
filename=fullfile(pathname,D(i).name);
temp(i)=xlsread(filename,'Sheet1','R4');
else
end
end
but I am getting the "Error using ==", "matrix dimensions must agree" error and I cannot find a way to make Matlab find the file that looks like 'Nominal' or 'Nominal.xls' (I have tried both). Please help!
댓글 수: 1
per isakson
2014년 7월 28일
편집: per isakson
2014년 7월 28일
- See regular expressions or
D = dir( '*Nominal.xls' );
' Matlab don't support anything close to D(i).name=='*Nominal.xls'
채택된 답변
추가 답변 (3개)
Image Analyst
2014년 7월 29일
Don't use
D(i).name=='*Nominal.xls'
use strfind() instead
if ~isempty(strfind(D(i).name, 'Nominal.xls')) % Don't use *Nominal use Nominal
댓글 수: 4
Alex
2014년 7월 29일
Michael Haderlein
2014년 7월 29일
Have you tried? I guess you mix up strfind with strmatch.
per isakson
2014년 7월 29일
편집: per isakson
2014년 7월 29일
@Alex, try this
filename = '081213_Nominal.xls';
pos = strfind( filename, 'Nominal.xls' )
isf = not( isempty( strfind( filename, 'Nominal.xls' ) ) )
it returns
pos =
8
isf =
1
Image Analyst
2014년 7월 30일
I agree with the others. strfind would have worked if you had just tried it, and as per just proved. The fact that a time stamp is somewhere in the filename does not matter at all - not sure why you thought it would unless you just didn't even read the documentation for the strfind function.
per isakson
2014년 7월 29일
An alternative
D = dir( fullfile( pathname, '*Nominal.xls' ) );
for jj = 1 : length(D)
filespec = fullfile( pathname, D(jj).name );
temp(jj) = xlsread( filespec, 'Sheet1','R4');
end
John
2014년 7월 29일
0 개 추천
Hi. I would like to add one piece of advice. In MATLAB, string comparisons for the purposes of logical testing are best done with 'strcmp'. You likely got that matrix dimensions error because strings in MATLAB are character arrays and if the filenames have different lengths then so will the character vectors that represent them. Strcmp, strfind, etc... are the way to go for string comparisons.
카테고리
도움말 센터 및 File Exchange에서 Characters and Strings에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!