如何使用LinqToCsv

时间:2015-12-23 16:43:16

标签: c#

我正在使用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; }

填充PropFour& PropFive我需要将CommonIdDifferentViewModel属性引入原始模型。我现在遇到的问题是当我写文件时它包含这两个属性,即使我没有给它们一个字段索引。

我尝试过设置:

IgnoreUnknownColumns = true

希望也许因为我没有装饰这些属性,它们可能被归类为未知,但它们仍然被输出。有没有办法从输出CSV中排除这些属性,除了创建新模型减去这些属性并在写入之前映射到此模型。

修改

一些进一步的阅读材料向我展示了

  

“没有FieldIndex的字段和属性最后写入,随机   令“。

解释了为什么这些仍然在我的输出CSV中显示,我现在也明白IgnoreUnknownColumns是用于阅读而不是写作,所以显然不会影响我添加到我的CSV中的不需要的属性。< / p>

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

1 个答案:

答案 0 :(得分:4)

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

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

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]属性。

了解更多信息click here。不确定为什么我没有发现这个现有的功能,但这里是为了其他任何人的利益。