c#中DataTable轉(zhuǎn)List的2種方法示例
在項(xiàng)目中常常常使用到DataTable,假設(shè)DataTable使用得當(dāng),不僅能使程序簡(jiǎn)潔有用,并且可以提高性能,達(dá)到事半功倍的效果,List<T>類(lèi)是ArrayList類(lèi)的泛型等效類(lèi),該類(lèi)使用大小可按需動(dòng)態(tài)增加的數(shù)組實(shí)現(xiàn)IList<T>泛型接口。這篇文章主要介紹了c# DataTable 轉(zhuǎn) List的兩種方法,下面來(lái)一起看看吧。
1. 直接寫(xiě)一個(gè)datatable轉(zhuǎn)list的類(lèi)
2. 利用泛型來(lái)寫(xiě),更加通用
public List<Dictionary<string, object>> DatatoTable(DataTable dt) { List<Dictionary<string, object>> list = new List<Dictionary<string, object>>(); foreach (DataRow dr in dt.Rows)//每一行信息,新建一個(gè)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>(); // 獲得此模型的類(lèi)型 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; } }
第二個(gè)方法在使用的時(shí)候需要注意:T為自己定義的類(lèi),其中的屬性需要與數(shù)據(jù)庫(kù)對(duì)應(yīng)
總結(jié)
到此這篇關(guān)于c#中DataTable轉(zhuǎn)List的2種方法的文章就介紹到這了,更多相關(guān)c# DataTable轉(zhuǎn)List內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C#中泛型舉例List<T>與DataTable相互轉(zhuǎn)換
- C#中將DataTable轉(zhuǎn)化成List<T>的方法解析
- C#實(shí)現(xiàn)DataTable,List和Json轉(zhuǎn)換的方法
- C#實(shí)現(xiàn)DataTable轉(zhuǎn)換成IList的方法
- C#將DataTable轉(zhuǎn)化為L(zhǎng)ist<T>
- C#將DataTable轉(zhuǎn)換成list的方法
- c#的datatable轉(zhuǎn)list示例
- c#將list類(lèi)型轉(zhuǎn)換成DataTable方法示例
- C#中DataTable和List互轉(zhuǎn)的示例代碼
相關(guān)文章
asp.net(C#)清除全部Session與單個(gè)Session的方法
下面小編就為大家?guī)?lái)一篇asp.net(C#)清除全部Session與單個(gè)Session的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12C#開(kāi)發(fā)中經(jīng)常用的加密解密方法示例
這篇文章主要給大家介紹了關(guān)于C#開(kāi)發(fā)中經(jīng)常用的加密解密方法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07c#實(shí)現(xiàn)ini文件讀寫(xiě)類(lèi)分享
c#實(shí)現(xiàn)ini文件讀寫(xiě)類(lèi)分享,大家參考使用吧2013-12-12Winform窗口實(shí)現(xiàn)多顯示屏顯示的2種方法
這篇文章主要介紹了Winform窗口實(shí)現(xiàn)多顯示屏顯示的2種方法,本文直接給出了實(shí)現(xiàn)代碼,并對(duì)其中的一些重要參數(shù)做了解釋,需要的朋友可以參考下2015-06-06