使用AutoMapper将对象字段映射到数组?

时间:2011-02-16 17:39:22

标签: c# asp.net entity automapper

C#中的automapper是否可以将对象的属性映射到数组/字典?我尝试过以下方法:

Mapper.CreateMap<FFCLeads.Models.FFCLead, Dictionary<string, SqlParameter>>()
    .ForMember(d => d["LeadID"], o => o.MapFrom(s => new SqlParameter("LeadID", s.LeadID)))
    .ForMember(d => d["LastName"], o => o.MapFrom(s => new SqlParameter("LastName", s.LastName)));

但是,它不起作用(对象引用未设置为实例)。基本上,我正在尝试将此对象的值设置为SqlParameter对象的数组。可能?如果是这样,这样做的正确方法是什么?感谢。

1 个答案:

答案 0 :(得分:5)

我使用以下方法:

IDictionary<string, object> GetDictionaryFromObject(object obj)
{
    if(obj == null) return new Dictionary<string, object>();
    return obj.GetType().GetProperties().
                ToDictionary(p => p.Name,
                             p => p.GetValue(obj, null) ?? DBNull.Value);
}