gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 20:39:20 27 4
gpt4 key购买 nike

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

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

我试过设置:

IgnoreUnknownColumns = true

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

编辑

一些进一步的阅读告诉我

"Fields and properties without FieldIndex get written last, in random order."

这解释了为什么这些仍然显示在我的输出 CSV 中,而且我现在也明白 IgnoreUnknownColumns 用于读取,而不是写入,因此显然不会影响我添加到我的不需要的属性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] 属性。

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

关于c# - 如何使用 LinqToCsv 从输出 CSV 中排除属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34440170/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com