Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/280.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# csvhelper从行中的不同项映射字段_C#_Csvhelper - Fatal编程技术网

C# csvhelper从行中的不同项映射字段

C# csvhelper从行中的不同项映射字段,c#,csvhelper,C#,Csvhelper,我从不具有相同列的csv文件导入记录。 我正在尝试创建一个映射,该映射将查看是否缺少一列,然后查看另一列,并在此基础上为第一列创建一个值 我试过这样的方法: Map(m => m.ImportNo).TypeConverter<PeriodConverter>(); Map(m => m.Period).Optional(); 但它失败了,因为没有ImportNo列。 另一方面,如果我将映射的代码更改为: Map(m => m.ImportNo).Optional

我从不具有相同列的csv文件导入记录。 我正在尝试创建一个映射,该映射将查看是否缺少一列,然后查看另一列,并在此基础上为第一列创建一个值

我试过这样的方法:

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();