c#中DataTable轉List的2種方法示例
在項目中常常常使用到DataTable,假設DataTable使用得當,不僅能使程序簡潔有用,並且可以提高性能,達到事半功倍的效果,List<T>類是ArrayList類的泛型等效類,該類使用大小可按需動態增加的數組實現IList<T>泛型接口。這篇文章主要介紹瞭c# DataTable 轉 List的兩種方法,下面來一起看看吧。
1. 直接寫一個datatable轉list的類
2. 利用泛型來寫,更加通用
public List<Dictionary<string, object>> DatatoTable(DataTable dt) { List<Dictionary<string, object>> list = new List<Dictionary<string, object>>(); foreach (DataRow dr in dt.Rows)//每一行信息,新建一個Dictionary<string,object>,將該行的每列信息加入到字典 { Dictionary<string, object> result = new Dictionary<string, object>(); foreach (DataColumn dc in dt.Columns) { result.Add(dc.ColumnName, dr[dc].ToString()); } list.Add(result); } return list; }
public class TabletoList { public static List<T> TableToListModel<T>(DataTable dt) where T : new() { // 定義集合 List<T> ts = new List<T>(); // 獲得此模型的類型 Type type = typeof(T); string tempName = ""; foreach (DataRow dr in dt.Rows) { T t = new T(); // 獲得此模型的公共屬性 PropertyInfo[] propertys = t.GetType().GetProperties(); foreach (PropertyInfo pi in propertys) { tempName = pi.Name; // 檢查DataTable是否包含此列 if (dt.Columns.Contains(tempName)) { // 判斷此屬性是否有Setter if (!pi.CanWrite) continue; object value = dr[tempName]; if (value != DBNull.Value) pi.SetValue(t, value, null); } } ts.Add(t); } return ts; } }
第二個方法在使用的時候需要註意:T為自己定義的類,其中的屬性需要與數據庫對應
總結
到此這篇關於c#中DataTable轉List的2種方法的文章就介紹到這瞭,更多相關c# DataTable轉List內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- None Found