我有一个带有txt文件的目录结构。
我想要一个文件名列表,其中修改/创建日期在一个范围之间。
到目前为止,我有这样的想法:
DirectoryInfo directory = new DirectoryInfo(@"C:\MotionWise\Manifest\000EC902F17F");
DateTime from_date = DateTime.Now.AddMinutes(-300);
DateTime to_date = DateTime.Now;
List<FileInfo> files = directory.GetFiles("*", SearchOption.AllDirectories).Where(file => file.LastWriteTime >= from_date && file.LastWriteTime <= to_date).ToList();现在,我只对完整的路径名称感兴趣。
如果我通过文件列表枚举,我可以将完整的路径名添加到一个新的列表/数组中,但是这似乎是在浪费额外的精力,因为我觉得在lambada代码中有一种方法可以做到这一点?
如果可以在lambada代码中完成,按文件信息选择的内容会不会太“重”?有没有一种方法只是选择完整的路径名称,而不“加载”每个条目到一个文件的信息?
我一直在尝试执行DOS命令并在Process类中捕获输出。
发布于 2013-11-14 19:20:20
如果您只对路径感兴趣,请不要使用DirectoryInfo.GetFiles,因为它返回一个数组,并且因为它是一个FileInfo[],其中每个FileInfo对象都包含您不感兴趣的所有信息。您可以使用File.GetLastWriteTime来获取它。
相反,使用Directory.EnumerateFiles,它只返回匹配筛选条件和搜索模式的路径。
List<string> paths = Directory.EnumerateFiles(@"C:\MotionWise\Manifest\000EC902F17F", "*", SearchOption.AllDirectories)
.Where(path => {
DateTime lastWriteTime = File.GetLastWriteTime(path);
return lastWriteTime >= from_date && lastWriteTime <= to_date;
})
.ToList();发布于 2013-11-14 19:17:11
只有Select在FullName上
List<string> files = directory.GetFiles("*", SearchOption.AllDirectories)
.Where(file => file.LastWriteTime >= from_date && file.LastWriteTime <= to_date)
.Select(f => f.FullName)
.ToList();https://stackoverflow.com/questions/19986321
复制相似问题