我有一个正则表达式定义感兴趣的文件名.列出符合此条件的目录中的所有文件的最佳方法是什么?
我的尝试是:
f = dir(DIR); f = {f([f.isdir] == 0).name}; result = f(~cellfun(@isempty,regexpi(f,'.*(avi|mp4)')));
但是,我想知道是否有更快和/或更清洁的解决方案呢?
是否可以简化它,如果不是正则表达式,我只有一个可能的文件扩展名列表?
从根本上说,你的方法就是我想要的.但是,您的代码行可以简化为(目录在正则表达式和最终串联中的空单元格中丢失):
原文链接:https://www.f2er.com/regex/356815.htmlf = dir('C:\directory'); f = regexpi({f.name},'.*txt|.*pdf','match'); f = [f{:}];
dir('C:\directory\*.avi')
这意味着您可以立即仅检索与扩展名匹配的文件,但是您必须循环扩展数量:
d = 'C:\users\oleg\desktop'; ext = {'*.txt','*.pdf'}; f = []; for e = 1:numel(ext) f = [f; dir(fullfile(d,ext{e}))]; end
替代方案(不推荐)
ext = {'*.txt','*.pdf'}; str = ['!dir ' sprintf('%s ',ext{:}) '/B']; textscan(evalc(str),'%s','Delimiter','')
其中str是!dir * .txt * .pdf / B和evalc()捕获字符串的评估,而textscan()则解析它.