C# CsvHelper缺失字段列表
借用本帖-。假设我有以下代码:C# CsvHelper缺失字段列表,c#,csvhelper,C#,Csvhelper,借用本帖-。假设我有以下代码: public sealed class DataMapper : CsvClassMap<DataType> { public DataMapper() { Map(m => m.Field1).Name("FirstField"); Map(m => m.Field2).ConvertUsing(m => { return 0; }); // required field
public sealed class DataMapper : CsvClassMap<DataType>
{
public DataMapper()
{
Map(m => m.Field1).Name("FirstField");
Map(m => m.Field2).ConvertUsing(m => { return 0; }); // required field
Map(m => m.Field3).ConvertUsing(m => { return 1; }); // required field
}
}
公共密封类数据映射器:CsvClassMap
{
公共数据映射器()
{
Map(m=>m.Field1).Name(“FirstField”);
Map(m=>m.Field2).ConvertUsing(m=>{return 0;});//必填字段
Map(m=>m.Field3).ConvertUsing(m=>{return 1;});//必填字段
}
}
如果我尝试加载csv文件,但字段2和字段3缺失,如何获取缺失字段的列表?我知道我可以检查ConvertUsing语句中是否存在该字段,但是如果我抛出异常,一次只能得到一个
我看过HeaderValidated和MissingFieldFound,但当它们被映射时,就我所知,它们并没有被这些方法处理
有什么想法吗?我最后添加了一个名为Errors的字段,并在该映射中进行了所有验证
Map(m => m.Errors).ConvertUsing(m => {
// do a bunch of validation
return "all of the errors";
});
这感觉像是重复的工作,因为我仍然需要对ConvertUsing语句进行验证,以用于我的实际字段,但这起到了作用,结果证明还可以