提问人:CvRChameleon 提问时间:3/2/2021 更新时间:3/2/2021 访问量:818
为 CsvHelper.Configuration.ClassMap<T 动态分配的属性>
Dynamic assigned Properties for CsvHelper.Configuration.ClassMap<T>
问:
我想通过动态分配的属性来使用。CsvHelper.Configuration.ClassMap
通常,您以静态方式映射属性:您必须分配每个属性及其“要显示的文本”。
using CsvHelper.Configuration;
public sealed class CleanSQLRowDescriptorMap : ClassMap<CleanSQLRowDescriptor>
{
public CleanSQLRowDescriptorMap()
{
Map(f => f.OriginalIndex).Name("Original Index");
Map(f => f.OriginalRow).Name("Original Row");
}
}
我想做以下事情:
using CsvHelper.Configuration;
public sealed class CleanSQLRowDescriptorMap : ClassMap<CleanSQLRowDescriptor>
{
public CleanSQLRowDescriptorMap()
{
// Filter by attribute (implementation returns PropertyInfo List)
List<PropertyInfo> mappedProperties = CleanSQLRowDescriptor.Create().FilterPropertiesByAttribute();
// Dynamically assign each property and its assigned 'attribute value'
// At the moment I mapped the PropertyInfo.Name, but I actually need to use the Property as the static example above.
// Also need to figure out how to get the Attribute value (DisplayName in this example).
mappedProperties.ForEach(prop => Map(f => prop.Name).Name(prop.Name));
}
}
我目前在上面使用了以下方法:
[DisplayName("Original Index")]
public int OriginalIndex { get; set; }
[DisplayName("Original Row")]
public string OriginalRow { get; set; }
public string DonotWantToAssignThis { get; set; }
public List<PropertyInfo> FilterPropertiesByAttribute()
{
// This function already returns only the attributes that use
// [DisplayName] and other attributes defined for other properties,
// ignoring other properties that do not have any of these attributes.
return properties;
}
如何使用 PropertyInfo 项目列表来动态分配 ClassMap?我想创建一个具有这些属性作为过滤器的基类,并且实现此基类的所有类都将具有相同的功能,从而更容易“维护映射”。
答:
2赞
CvRChameleon
3/2/2021
#1
我设法弄清楚了,VS Code 没有给我所有的功能重载,所以我错过了重载。Map()
这在所有示例中都使用:
MemberMap<TClass, TMember> Map<TMember>(Expression<Func<TClass, TMember>> expression, bool useExistingMap = true);
我在 JoshClose/CSVHelper 中找到了这一点:
public MemberMap Map(Type classType, MemberInfo member, bool useExistingMap = true)
因此,与其使用不采用类型的“要求属性名称为 TMember 的表达式”,我现在可以直接分配。MemberInfo
下面的代码仅显示了单个属性 [DisplayName] 的解决方案,方法是使用其 .DisplayName 属性值。
对于我目前拥有的其他属性,我将需要以不同的方式处理属性值:
mappedProperties.ForEach(prop =>
{
Map(typeof(CleanSQLRowDescriptor), prop).Name(prop.GetCustomAttribute<DisplayNameAttribute>().DisplayName);
});
评论