如何使用LinqToCsv从输出CSV中排除属性

本文关键字:排除 属性 CSV 输出 何使用 LinqToCsv | 更新日期: 2023-09-27 18:27:56

我使用LinqToCsv输出基于以下模型的CSV文件。

[CsvColumn(Name = "Column_A", FieldIndex = 0)]
public string PropOne { get; set; }
[CsvColumn(Name = "Column_B", FieldIndex = 1)]
public bool PropTwo { get; set; }
[CsvColumn(Name = "Column_C", FieldIndex = 2)]
public bool PropThree { get; set; }
[CsvColumn(Name = "Column_D", FieldIndex = 3)]
public int PropFour { get; set; }
[CsvColumn(Name = "Column_E", FieldIndex = 4)]
public string PropFive { get; set; }
//I don't want the below to be output in my CSV
public int CommonId { get; set; }
public DifferentViewModel DifferentViewModel { get; set; }

为了填充CCD_ 2&PropFive我需要将CommonIdDifferentViewModel属性引入到原始模型中。我现在遇到的问题是,当我编写文件时,它包括这两个属性,尽管我没有给它们一个字段索引。

我尝试过设置:

IgnoreUnknownColumns = true

我希望,也许因为我没有装饰这些房产,它们可能会被归类为未知,但它们仍然被输出。除了创建一个新的模型减去这些属性并在写入之前映射到这个模型之外,有没有任何方法可以将这些属性从输出CSV中排除。

编辑

一些进一步的读数显示

"没有FieldIndex的字段和属性最后写入,随机顺序"

这解释了为什么这些仍然显示在我的输出CSV中,我现在也明白了IgnoreUnknownColumns是用于读取而不是写入的,所以很明显,它不会影响我不想要的属性添加到我的CSV中。

但我在文档中仍然找不到任何关于排除属性的内容,看起来我将不得不拆分这个模型,一个用于设置,另一个用于实际编写。

如何使用LinqToCsv从输出CSV中排除属性

我从git克隆了项目,并更仔细地检查了代码,因为我打算按照Will的建议添加ignore属性。

FieldMapper.cs中找到WriteObject方法后,我注意到库实际上已经在做我想要的事情:

if (m_fileDescription.EnforceCsvColumnAttribute &&
(!tfi.hasColumnAttribute))
{
   continue;
}

因此,通过在实例化新的CsvFileDescription时将其设置为true,如下所示:

CsvFileDescription outputFileDescription = new CsvFileDescription
{
   SeparatorChar = ',', // comma delimited
   FirstLineHasColumnNames = true, // column names in first record
   FileCultureName = "en-GB", // use formats used in the UK
   EnforceCsvColumnAttribute = true // don't output if there is no csv column attribute                
};

输出将不再包含不需要的列,因为这些属性在我的模型中不包含[CsvColumn]属性。

有关更多信息,请单击此处。不知道为什么我没有发现这个现有的功能,但这是为了其他人的利益。