我正在尝试查找具有上次写入日期的文件并将其复制到其他位置。它正确找到文件,但是当我尝试复制它时,它无法找到它刚找到的文件。这是在SSIS脚本任务中。
DirectoryInfo directory = new DirectoryInfo(@"path");
FileInfo[] files = directory.GetFiles();
//files that have been written to in the last 3 days
DateTime lastWrite = DateTime.Now.AddDays(-3);
foreach (FileInfo latestFile in files)
{
// if its the correct name
if (latestFile.Name.StartsWith("OMC"))
{
// if its in the last 3 days
if (latestFile.LastWriteTime > lastWrite)
{
lastWrite = latestFile.LastWriteTime;
// this correctly find the file and puts it into the file variable.
file = latestFile.ToString();
// this errors out saying it cannot find the file.
// (Does not even go to the outputFile)
File.Copy(file, outputFile, true); // <- error
//backs the file up
File.Copy(file, backupfile, true);
}
}
}
答案 0 :(得分:4)
FileInfo.ToString()
返回文件名,但为了复制它,您需要完整路径。变化
file = latestFile.ToString();
要
file = latestFile.FullName;
并试一试。
答案 1 :(得分:2)
latestFile.ToString()
评估的内容是什么?这是一种获取路径的奇怪方式。
像文档中所示使用FileInfo.FullName
。
您可以使用调试器自行查找此类错误。
答案 2 :(得分:2)
您可能需要构建完整路径,而不是使用Fileinfo.ToString()
:
file = latestFile.FullName;
来自MSDN:
有些情况下,ToString方法返回的字符串不代表完全限定的路径。例如,使用GetFiles方法创建FileInfo对象时,ToString方法不代表完全限定的路径。