1. 程式人生 > 其它 >List<T>/IEnumerable轉換到DataTable/DataView

List<T>/IEnumerable轉換到DataTable/DataView

//這裡是List<T> 轉DataTable的方法主體

1
public DataTable ToDataTable<T>(List<T> items) 2 { 3 var tb = new DataTable(typeof(T).Name); 4 5 PropertyInfo[] props = typeof(T).GetProperties(BindingFlags.Public | BindingFlags.Instance); 6 7 foreach
(PropertyInfo prop in props) 8 { 9 Type t = GetCoreType(prop.PropertyType); 10 tb.Columns.Add(prop.Name, t); 11 } 12 13 foreach (T item in items) 14 { 15 var values = new object[props.Length]; 16 17 for
(int i = 0; i < props.Length; i++) 18 { 19 values[i] = props[i].GetValue(item, null); 20 } 21 22 tb.Rows.Add(values); 23 } 24 25 return tb; 26 }

下面是方法的使用:比如你有一個List<T>集合。
我這裡是通過介面獲得的List<T>,來演示。使用方法:

 1 new ListToDataTable().ToDataTable() 

ToDataTable()括號內就是你的List<t>。

 1 DataTable dtnn = new ListToDataTable().ToDataTable(await mService.GetProductlevel(Catalog_No));