CSV分析和输出

时间:2015-05-20 22:51:55

标签: c# csv csvhelper

我目前正在尝试分析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();
                    }
                }
            }
        }
    }
}

1 个答案:

答案 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();

假设按预期工作一点点?