我有一个泛型类,其中我有一个函数来获取传递的泛型对象的属性。它如下所示。
public class ExportToCsv<T>
where T: class
{
public ExportToCsv(List<T> obj)
{
this.Data = obj;
}
public StringBuilder CreateRows()
{
IEnumerable<PropertyInfo> properties = typeof(T).GetProperties();
}
}
如果通过从下面的对象(类)中选择
来传递对象,它可以正常工作并返回属性//GetLeadingRoutingRecords returns a class/object
var result = from obj in GetLeadRoutingRecords()
select new
{
LeadRoutingId = obj.LeadRoutingID,
Make = obj.Make
};
并将结果作为result.ToList();
但是当我尝试通过为下面的属性创建一个类来创建我自己的匿名对象时,它不起作用 没有返回任何属性
注意:下面的代码是在循环中调用的,它运行良好并传递给上面的函数可以通过调试查看所有值。
public CsvReport function return(){
return new CsvReport
{
ShopName = this.val,
TargetVehicleName = val
}.ToList();
}
我为上面的匿名对象编写的类如下所示:
public class CsvReport
{
public string ShopName { get; set; }
public string TargetVehicleName { get; set; }
}
所以在这种情况下它不起作用,我选择第一个记录并获得如下所示的属性
this.Data.First().GetType().GetProperties();
我想在这里使用第一个模式,即type(T).GetProperties
所以,任何工作请........................
答案 0 :(得分:31)
对typeof(T)
的反思很好;这是一个更简单的基于的示例,但是(重要的是) runnable 。它输出:
ShopName
TargetVehicleName
代码:
using System;
using System.Collections.Generic;
public class CsvReport
{
public string ShopName { get; set; }
public string TargetVehicleName { get; set; }
}
class ExportToCsv<T>
{
List<T> data;
public ExportToCsv(List<T> obj)
{
data = obj;
}
public void WritePropNames()
{
foreach (var prop in typeof(T).GetProperties())
{
Console.WriteLine(prop.Name);
}
}
}
static class Program
{
static void Main()
{
var obj = new List<CsvReport>();
obj.Add(new CsvReport { ShopName = "Foo", TargetVehicleName = "Bar" });
new ExportToCsv<CsvReport>(obj).WritePropNames();
}
}