为什么此代码不替换文本文件中的数据

本文关键字:文件 数据 文本 替换 代码 为什么 | 更新日期: 2023-09-27 17:58:37

我正在开发一个小型应用程序,它应该读取一个文件(ANSI 835),并用通用数据替换某些位置的数据。基本上,我试图从文件中删除一个人的名字。

我正在搜索的包含名称的行看起来像这样:

NM1*QC*1*Doe*John*R***MI*010088307    01~

我的代码如下:

string[] input_file = (string[])(e.Data.GetData(DataFormats.FileDrop));
string output_file = @"c:'scrubbed.txt";
foreach (string file in input_file)
{
    string[] lines = File.ReadAllLines(file);
    foreach (string line in lines)
    {
        if (line.StartsWith("NM1*QC"))
        {
            line.Split('*')[1] = "Lastname";
            line.Split('*')[2] = "Firstname";
        }
    }
    File.WriteAllLines(output_file, lines);
}

File.WriteAllLines可以工作,但数据没有被更改。我试图让任何以NM1*QC开头的行看起来像这样:

NM1*QC*1*Lastname*Firstname*R***MI*010088307    01~

文件中有许多行以NM1*QC开头。在这种情况下,"查找并替换"然后创建新文件的正确方法是什么?

一如既往,感谢您抽出时间!

为什么此代码不替换文本文件中的数据

String.Split的调用返回既不捕获也不使用的变量,它们不会更改底层字符串。所以你的代码相当于:

 if (line.StartsWith("NM1*QC"))
 {
     string[] split1 = line.Split('*')[1] = "Lastname";
     string[] split2 = line.Split('*')[2] = "Firstname";
 }

您需要获取split1split2的结果,并使用它们来重新创建字符串。以下是我如何重写您的代码:

string[] input_file = (string[])(e.Data.GetData(DataFormats.FileDrop));
string output_file = @"c:'scrubbed.txt";
foreach (string file in input_file)
{
    string[] lines = File.ReadAllLines(file);
    for (int i=0; i < lines.length; i++)
    {
        string line = lines[i];
        if (line.StartsWith("NM1*QC"))
        {
            string[] values = line.Split('*');
            values[1] = "Lastname";
            values[2] = "Firstname";
            lines[i] = String.Join("*", values);
        }
    }
    File.WriteAllLines(output_file, lines);
}

请注意,我正在使用String.Join方法重新组合各个值,并将新字符串插入行数组中。然后,它会像你所期望的那样被写出来。

这里您正在创建一个临时数组:

line.Split('*')

您正在更改其内容:

line.Split('*')[1] = "Lastname";

行执行完毕后,对这个临时数组的引用将丢失,您的更改也随之丢失。

为了保持更改,您需要直接写入lines:

for (var i = 0; i < lines.Length; ++i)
{
    var line = lines[i];
    if (!line.StartsWith("NM1*QC"))
    {
        continue;
    }
    var parts = line.Split('*');
    parts[3] = "Lastname";
    parts[4] = "Firstname";
    lines[i] = string.Join("*", parts);
}