我有一个泛型类,其中有一个函数来获取传递的泛型对象的属性。如下所示。
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
所以,请做任何工作。。。。。。。。。。。。。。。。。。。。。。。。
typeof(T)
上的反射工作正常;这里有一个基于的更简单的例子,但(重要的是)可运行。它输出:
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();
}
}