CsvHealper - 如何忽略 csv 中的空列

CsvHealper - How to ignore empty columns in csv

csvHelper 的新手。我想从 csv 文件中删除空列。 我正在使用 CsvWriter 将 csv 行定义 class 写入流。

这是我的代码:

var records = getRecords(); // list of row definition items
var stream = new MemoryStream();
var writer = new StreamWriter(stream);
using (var csv = new CsvWriter(writer))
{
    csv.WriteRecords(records);
    writer.Flush();
    return stream;
}

有没有办法让CsvWriter忽略空列?也许配置?

actual csv: 

First Name | Middle Name| Last Name |Gender
FName1     |            | LName1    | Male
FName2     |            | LName2    | Female
FName3     |            | LName3    | 


expected csv:

First Name | Last Name |Gender
FName1     | LName1    | Male
FName2     | LName2    | Female
FName3     | LName3    | 

项目记录到没有中间名的对象列表属性。像这样(使用 linq)

   var projectedRecords = records.Select(r => new PersonDto
   {
       FirstName = r.FirstName,
       LastName = r.LastName,
       Gender = r.Gender
    }).ToList();

然后将 projectedRecords 传递给 csvWriter。

可以使用配置来完成此操作。

public static void Main(string[] args)
{
    var records = new List<Foo>
    {
        new Foo { FirstName = "FName1", LastName = "LName1", Gender = "Male"},
        new Foo { FirstName = "FName2", LastName = "LName2", Gender = "Female"},
        new Foo { FirstName = "FName3", LastName = "LName3"},
    };

    using (var csv = new CsvWriter(Console.Out))
    {
        var map = new FooMap();

        var properties = typeof(Foo).GetProperties();

        foreach (var property in properties)
        {
            if(records.All(foo => property.GetValue(foo) == null))
            {
                map.Map(typeof(Foo), property).Ignore();
            }
        }

        csv.Configuration.RegisterClassMap(map);

        csv.WriteRecords(records);
    }

    Console.ReadKey();
}

public class Foo
{
    public string FirstName { get; set; }
    public string MiddleName { get; set; }
    public string LastName { get; set; }
    public string Gender { get; set; }
}

public class FooMap : ClassMap<Foo>
{
    public FooMap()
    {
        Map(m => m.FirstName).Name("First Name");
        Map(m => m.MiddleName).Name("Middle Name");
        Map(m => m.LastName).Name("Last Name");
        Map(m => m.Gender);
    }
}

如果您不想创建单独的 class 地图,只需将 FooMap 替换为 DefaultClassMap<Foo> 并使用 AutoMap.

var map = new DefaultClassMap<Foo>();
map.AutoMap();