[英]C# text file to string array and how to remove specific strings?
我需要读取一个文本文件 (10mb) 并转换为 .csv。 请参阅以下代码部分:
string DirPathForm = System.IO.Path.GetDirectoryName(System.Reflection.Assembly.GetEntryAssembly().Location);'
string[] lines = File.ReadAllLines(DirPathForm + @"\file.txt");
文本文件的某些部分具有模式。 所以,使用如下:
string[] lines1 = lines.Select(x => x.Replace("abc[", "ab,")).ToArray();
Array.Clear(lines, 0, lines.Length);
lines = lines1.Select(x => x.Replace("] CDE ", ",")).ToArray();
有些部分没有模式可以直接替换。 问题是如何删除这部分中的字符、数字和空格。 请看下面?
string[] lines = {
"a] 773 b",
"e] 1597 t",
"z] 0 c"
};
得到以下结果:
string[] result = {
"a,b",
"e,t",
"z,c"
};
obs:删除的项目需要用“,”替换。
首先,您不应该使用 ReadAllLines,因为它是一个巨大的文件操作。 它会将所有数据加载到 RAM 中,这是不正确的。 相反,请在循环中逐行阅读。
其次,您绝对可以使用正则表达式将数据从第一个条件替换为第二个条件。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.