C# csvhelper从行中的不同项映射字段
我从不具有相同列的csv文件导入记录。 我正在尝试创建一个映射,该映射将查看是否缺少一列,然后查看另一列,并在此基础上为第一列创建一个值 我试过这样的方法:C# csvhelper从行中的不同项映射字段,c#,csvhelper,C#,Csvhelper,我从不具有相同列的csv文件导入记录。 我正在尝试创建一个映射,该映射将查看是否缺少一列,然后查看另一列,并在此基础上为第一列创建一个值 我试过这样的方法: Map(m => m.ImportNo).TypeConverter<PeriodConverter>(); Map(m => m.Period).Optional(); 但它失败了,因为没有ImportNo列。 另一方面,如果我将映射的代码更改为: Map(m => m.ImportNo).Optional
Map(m => m.ImportNo).TypeConverter<PeriodConverter>();
Map(m => m.Period).Optional();
但它失败了,因为没有ImportNo列。
另一方面,如果我将映射的代码更改为:
Map(m => m.ImportNo).Optional().TypeConverter<PeriodConverter>();
Map(m => m.Period).Optional();
Map(m=>m.ImportNo).Optional().TypeConverter();
Map(m=>m.Period).Optional();
通过添加可选的()
它只是忽略了我创建的类型转换器。
有没有更好的方法来编写此转换器以使其工作?
转换器使用
应该可以工作
Map(m=>m.ImportNo).ConvertUsing(行=>
{
if(行TryGetField(“输入”,输出输入输入输入))
{
返回进口编号;
}
if(第行“期间”)=“2012年8月-2012年12月”)
返回1;
else if(第行获取字段(“期间”)=“2013年1月-2013年6月”)
返回2;
其他的
返回0;
});
Map(m=>m.Period).Optional();
Map(m => m.ImportNo).Optional().TypeConverter<PeriodConverter>();
Map(m => m.Period).Optional();