CsvHealper - Как игнорировать пустые столбцы в CSV

Впервые в csvHelper. Я хочу удалить пустые столбцы из файла csv. Я использую CsvWriter для записи класса определения строки csv в поток.

Вот мой код:

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    | 


person Mhadipor    schedule 14.08.2019    source источник
comment
Вы говорите, что все объекты в вашем списке записей имеют свойство отчество, которое всегда пусто?   -  person Dave Barnett    schedule 14.08.2019


Ответы (2)


Для этого можно использовать конфигурацию.

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);
    }
}

А если вы не хотите создавать отдельную карту классов, просто замените FooMap на DefaultClassMap<Foo> и используйте AutoMap.

var map = new DefaultClassMap<Foo>();
map.AutoMap();
person David Specht    schedule 20.08.2019

Запись проекта в список объектов, у которых нет свойства отчество. Что-то вроде этого (используя linq)

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

Затем передайте projectedRecords в csvWriter.

person Dave Barnett    schedule 14.08.2019