我目前正在尝试分析CSV文件,然后仅输出符合特定条件的项目。我正在使用CSVHelper库。
到目前为止,我能够导入文件,我可以将其导出,...等等。
由于某种原因,条目数量增加了三倍。如同,它成功地遍历值,然后连续两次输出所有值。像:
A
B
C
D
A
A
B
B
C
C
D
D
这就是问题1.为什么?
问题2:如何使其过滤并仅输出符合标准的数据?第2栏是年龄,年龄必须为62岁或以上。
以下是我的代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.IO;
using System.Diagnostics;
using CsvHelper;
using System.Collections;
namespace firstdraft
{
class Program
{
public String Name { get; set; }
public String Age { get; set; }
private static void Main(string[] args)
{
using (var sr = new StreamReader(@"people.csv"))
{
using (var sw = new StreamWriter(@"results.csv"))
{
var reader = new CsvReader(sr);
var writer = new CsvWriter(sw);
IEnumerable<Program> records = reader.GetRecords<Program>().ToList();
writer.WriteRecords(records);
foreach (Program record in records)
{
writer.WriteRecord(record);
writer.WriteField(record.Name);
writer.WriteField(record.Age);
writer.NextRecord();
}
}
}
}
}
}
答案 0 :(得分:1)
您正在撰写记录3次。首先,全部写出来(A B C D):
!important
接下来,您在迭代它们时编写每条记录:
writer.WriteRecords(records);
然后你又一次又一次地写着它:
writer.WriteRecord(record);
你想在那里实现什么目标?
对于过滤,您可能希望通过LINQ执行类似的操作:
writer.WriteField(record.Name);
writer.WriteField(record.Age);
writer.NextRecord();
假设按预期工作一点点?