[英]Reading CSV with optional column using CsvHelper
我想读取一个包含一些可选列的 CSV 文件,为此我使用“?”定义了一个具有可选属性的类。 但不能让它发挥作用。
public class MyItem
{
public int Id { get; set; }
public int? MyValue { get; set; }
}
映射类:
public sealed class MyItemMap : ClassMap<MyItem>
{
public MyItemMap()
{
Map(m => m.Id);
Map(m => m.MyValue);
}
}
然后是一个控制台应用程序:
static void Main(string[] args)
{
using (var reader = new StreamReader(@"C:\Test2Delete\ConsoleAppCSV\MyItem.csv"))
using (var csv = new CsvReader(reader))
{
csv.Configuration.RegisterClassMap(new MyItemMap());
csv.Configuration.HeaderValidated = null;
try
{
var records = csv.GetRecords<MyItem>();
foreach (var r in records)
{
Console.WriteLine(r.Id + " " + r.MyValue);
}
Console.ReadLine();
}
catch (Exception e)
{
Console.WriteLine(e.Message);
Console.ReadLine();
}
}
}
}
所以我希望能够读取包含“Id”、“MyValue”列的文件以及仅包含“Id”列的文件。 我怎样才能做到这一点?
将MyValue
设置为可选。
public sealed class MyItemMap : ClassMap<MyItem>
{
public MyItemMap()
{
Map(m => m.Id);
Map(m => m.MyValue).Optional();
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.