我在对源文件中的某些数据进行某些更改后,尝试从一个文件写入临时文件。这一直有效,直到我将这个逻辑提取到它自己的函数中。
运行一些测试后,我注意到只有第一行被保存到我指定的位置的文件中。调试后,我能够从第二次调用此功能看到,然后文件位置位于完全不同的位置。
我有两个问题,第一个 - 为什么会发生这种情况?第二 - 确保这一点得到修复并且不会再发生的最佳方法是什么?
str []是分隔符一次分隔一行的文件。 filename是文件目录中包含的特定文件的名称(该程序循环遍历许多文件)。
public static void writeFile(string[] str, string filename)
{
rowCount++;
using (StreamWriter sw = new StreamWriter(filename.Substring(0, filename.Length - 4) + "_tmp.txt", true, System.Text.Encoding.Unicode))
{
string tempString = String.Empty;
for (int i = 0; i < str.Length; i++)
{
if (isMRT)
{
tempString += str[i] + ",";
}
else
{
tempString += str[i] + "|";
}
}
logger.LogMessage("Writting line to file: " + "Row #: " + rowCount + " ,File Path: " + filename.Substring(0, filename.Length - 4) + "_tmp.txt");
sw.WriteLine(tempString);
}
}
编辑: 这是我的目录和文件列表以及调用write方法的函数
static string directory = ConfigurationManager.AppSettings["Directory"];
static List<String> fileNames = Directory.GetFiles(directory).ToList();
private static void activityCheck(string filename, string[] allLines)
{
foreach (string nextLine in allLines.Skip(1))
{
string[] tempLine;
if (isMRT)
{
tempLine = nextLine.Split(',');
}
else
{
tempLine = nextLine.Split('|');
}
logger.LogMessage("Checking Activity flag...");
if (tempLine[count].Length == 6)
{
checkColumn(tempLine);
logger.LogMessage("Activity flag is OK");
writeFile(tempLine, filename);
}
else if (tempLine[count].Length > 6)
{
tempLine[count] = tempLine[count].Trim();
checkColumn(tempLine);
logger.LogMessage("FIXED Activity flag");
writeFile(tempLine, filename);
}
else
{
logger.LogMessage("The Activity flag did not have enough numbers in Row #: " +rowCount);
//throw new Exception("There are not enough numbers in the Activity flag");
}
}
}
EDIT2: 新建的临时文件在Project的bin文件夹中的Visual Studio文件夹中创建。不确定这对于之前可能遇到此问题的人是否有用。
答案 0 :(得分:0)
我找到了解决问题的方法。我原来只是传递文件的名称而不是整个路径。当然我错过了一个函数调用,我仍在传递文件名,而不是通往项目目录中创建临时文件的路径。
找到后快速修复:
activityCheck(nameOfFile, allLines);
到
activityCheck(pathToFile, allLines);
如果有人发现在Project / bin / Debug位置创建了文件,并且您知道正确设置了目标目录,请仔细检查您是否正在传递实际路径。