我不确定我是否正确解释这个问题,或者问题是否足够明确,但这就是我想要做的事情。
我创建了一个名为index的对象,它存储IList中元素的索引。这是我的ojbect索引。
var index = new
{
PhoneReportID = 1,
CSQID = i.NextIndex(),
CallsPresented = i.NextIndex(),
AvgQueueTime = i.NextIndex(),
CallsHandled = i.NextIndex(),
AvgAnswerSpeed = i.NextIndex(),
AvgHandleTime = i.NextIndex(),
CallsAbandoned = i.NextIndex(),
AvgAbandonTime = i.NextIndex(),
AvgCallsAbandoned = i.NextIndex(),
CallsDequeued = i.NextIndex(),
AvgDequeueTime = i.NextIndex(),
CallsHandledByOther = i.NextIndex(),
MaxQueueTime = z.NextIndex(),
MaxHandleTime = z.NextIndex(),
MaxAbandonTime = z.NextIndex(),
MaxCallsAbandoned = z.NextIndex(),
MaxDequeueTime = z.NextIndex(),
};
这是我的泛型方法,它从泛型类型获取属性,并根据索引中的元素位置设置值。
private IEnumerable<T> Parse(IList<string[]> rows, object index)
{
Type indexType = index.GetType();
IList<PropertyInfo> indexProperties = indexType.GetProperties();
int k = 0;
var classType = typeof(T);
IList<PropertyInfo> classProperties = classType.GetProperties();
foreach (var property in classProperties)//.Select(x => x.ToString()).Select(y => y.Trim()).ToList())
{
var propGetter = property.GetGetMethod();
var propSetter = indexType.GetProperty(property.Name).GetSetMethod();
var valueToSet = rows[int.TryParse(index[indexType.GetProperty(property.Name)],out k)];
}
throw new Exception();
}
我这样做有很多原因,但我这样做的主要原因之一是在c#中学习反思。
因此,行是通过读取具有特定分隔符的文件获得的列表。由于列表中的每个值都对应于某个类的某些属性,因此我创建了一个名为index的对象,其名称与该类的属性名称相同,并为其分配了IList中值的位置。现在,我想使用索引的属性名称检索行中的值,该索引返回类的属性名称与对象索引的属性名称相同的位置。我上面做的方法对于检索值是不正确的,但是为了清楚我打算实现的目的,我写了它。希望我能够清楚地回答这个问题。
答案 0 :(得分:2)
private IEnumerable<T> Deserialize<T>(IList<string[]> rows, object index)
where T : new()
{
Type indexType = index.GetType();
IList<PropertyInfo> indexProperties = indexType.GetProperties();
var dtoType = typeof(T);
IList<PropertyInfo> dtoProperties = dtoType.GetProperties();
var setters = new List<Tuple<int,PropertyInfo>>();
foreach (var dtoProperty in dtoProperties)
{
var indexProperty = indexType.GetProperty(dtoProperty.Name);
var columnIndex = (int) indexProperty.GetValue(index);
setters.Add(Tuple.Create(columnIndex, dtoProperty));
}
foreach (var row in rows)
{
var dto = new T();
foreach (var pair in setters)
{
var colIndex = pair.Item1;
var prop = pair.Item2;
prop.SetValue(dto, row[colIndex]);
}
yield return dto;
}
}
where T : new()
是一个通用约束,仅允许具有无参数构造函数的类型。它允许您稍后使用new T()
,而不会让编译器尖叫。PropertyInfo.GetValue(object)
和PropertyInfo.SetValue(object, object)
而不是直接访问get-和set-methods,因为它更容易。