如果所有非可选字段为空,如何在 CsvHelper.Configuration 中配置跳过记录

Posted

技术标签:

【中文标题】如果所有非可选字段为空,如何在 CsvHelper.Configuration 中配置跳过记录【英文标题】:How to configure skip record in CsvHelper.Configuration if all non-optional fields are empty 【发布时间】:2021-12-01 06:08:15 【问题描述】:

我使用 CsvHelper.Configuration.ClassMap 来读取 csv。我使用可选和验证委托。

如果地图字段中所有非可选字段为空,我如何跳过行?

类映射

Map(m => m.Col1).Index(0).Name("Column 1").Optional();
Map(m => m.Col2).Index(0).Name("Column 1").Validate(field => !string.IsNullOrEmpty(field.Field));
Map(m => m.Col3).Index(0).Name("Column 1").Validate(field => !string.IsNullOrEmpty(field.Field));

CSV:

Col1 Col2 Col3

1 NULL NULL,其中“NULL” - 为空

并且在 deligate "ShouldSkipRecord" 中只有 String[] 和当前行的原始字符串。 文件中的字段顺序可能与地图中的索引不同,我无法通过索引获取字段的属性。

【问题讨论】:

【参考方案1】:

最终,您需要请求 Josh 向 ShouldSkipRecord 参数添加更多数据,以便检查哪些字段是必需的。这不是一个完美的解决方案,因为如果 任何 必填字段为空,它会跳过,但它可能会满足您的需求。

void Main()

    var config = new CsvConfiguration(CultureInfo.InvariantCulture)
    
        ReadingExceptionOccurred = args => 
        
            if (args.Exception is CsvHelper.FieldValidationException)
                return false;
            
            return true;            
        
    ;
    
    using (var reader = new StringReader("Col1,Col2,Col3\n1,,\n2,one,three\n3,,four"))
    using (var csv = new CsvReader(reader, config))
    
        csv.Context.RegisterClassMap<FooMap>();
        var records = csv.GetRecords<Foo>().ToList();
        records.Dump();
       


public class FooMap : ClassMap<Foo>

    public FooMap()
    
        Map(m => m.Col1).Optional();
        Map(m => m.Col2).Validate(field => !string.IsNullOrEmpty(field.Field));
        Map(m => m.Col3).Validate(field => !string.IsNullOrEmpty(field.Field));
    


public class Foo

    public string Col1  get; set; 
    public string Col2  get; set; 
    public string Col3  get; set; 

【讨论】:

以上是关于如果所有非可选字段为空,如何在 CsvHelper.Configuration 中配置跳过记录的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 AppSync 解析器和 Aurora 将可选字段插入为空?

检查 nil 的非可选值

如何自动创建一个实体,它与我正在创建的实体具有一对一的非可选关系?

为啥你可以在 Swift 中为可选类型分配非可选值?

Xcode NSManagedObject 子类在它们被标记为非可选时包含可选

防止 Obj-C 代码将 `nil` 传递给具有非可选参数的 Swift 方法