如何解决CSV Helper 映射中的嵌套集合
我有一个 Car 集合,包括生产日期、汽车名称、生产地点字段 - 这是一个名为 ProductionPlace 的新模型,包括 City、Address 和 Id,Cars 中有另一个集合是 Creator - 包括姓名、姓氏和国家。
所以这基本上是这样的
Cars
{
ProductionDate,Name,ProductionPlace
{
Id,City,Address
},Creator
{
Name,Surname,Country
}
如何使用 CSV Helper 映射那些? 例如,我收到“没有名为 Creator 的字段”。我可以简单地映射字段,但不能映射嵌套在我的主集合中的集合
编辑
My code as far looks like that
public void MapCar()
{
Map(mapping => mapping.Car).ConvertUsing(
row => { List<Car> car = new List<Car>
{
ProductionDate = row.GetField("ProductionDate"),Name = row.GetField("Name"),ProductionPlace = new ProductionPlace
{
Id = row.GetField("Id"),City = row.GetField("City"),Address = row.GetField("Address")
},Creator = new Creator
{
Name = row.GetField("Name"),Surname = row.GetField("Surname"),Country = row.GetFiele("Country")
}
};)}
Creator 和 ProductionPlace 都是独立的模型。而 Car 是一个使用这两个字段的模型。
解决方法
您现在真正遇到的唯一问题是 Car
和 Creator
的属性 Name
具有相同的名称。如果您使用 CsvHelper 名称属性,您可以在您的 CsvHeader 中为它们指定不同的名称,其余的将映射而无需您执行任何其他操作。
void Main()
{
var input = new StringBuilder();
input.AppendLine("ProductionDate,CarName,Id,City,Address,CreatorName,Surname,Country");
input.AppendLine("2021-06-03,Tesla,1,MyCity,MyAddress,Bob,Jones,MyCountry");
using (var reader = new StringReader(input.ToString()))
using (var csv = new CsvReader(reader,CultureInfo.InvariantCulture))
{
var records = csv.GetRecords<Car>().Dump();
}
}
public class Car
{
public DateTime ProductionDate { get; set; }
[Name("CarName")]
public string Name { get; set; }
public ProductionPlace ProductionPlace { get; set; }
public Creator Creator { get; set; }
}
public class ProductionPlace
{
public int Id { get; set; }
public string City { get; set; }
public string Address { get; set; }
}
public class Creator
{
[Name("CreatorName")]
public string Name { get; set; }
public string Surname { get; set; }
public string Country { get; set; }
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。