欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c#中DataTable轉(zhuǎn)List的2種方法示例

 更新時(shí)間:2021年04月12日 10:18:56   作者:chenweilong213  
這篇文章主要給大家介紹了關(guān)于c#中DataTable轉(zhuǎn)List的2種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

在項(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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#加密在實(shí)際中的應(yīng)用

    C#加密在實(shí)際中的應(yīng)用

    在系統(tǒng)的管理員有著實(shí)際的應(yīng)用,對(duì)于一個(gè)數(shù)據(jù)庫(kù)管理系統(tǒng)來(lái)說(shuō),數(shù)據(jù)庫(kù)安全還是挺重要的,所以在存入到數(shù)據(jù)庫(kù)的密碼通常都是加密的
    2012-11-11
  • c# 實(shí)現(xiàn)KMP算法的示例代碼

    c# 實(shí)現(xiàn)KMP算法的示例代碼

    這篇文章主要介紹了c# 實(shí)現(xiàn)KMP算法的示例代碼,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下
    2020-11-11
  • asp.net(C#)清除全部Session與單個(gè)Session的方法

    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-12
  • 從C#程序中調(diào)用非受管DLLs的方法

    從C#程序中調(diào)用非受管DLLs的方法

    這篇文章主要介紹了從C#程序中調(diào)用非受管DLLs的方法,是非常實(shí)用的技巧,有助于深入理解Windows程序設(shè)計(jì),需要的朋友可以參考下
    2014-10-10
  • C#開(kāi)發(fā)中經(jīng)常用的加密解密方法示例

    C#開(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-07
  • 詳解C#App.config和Web.config加密

    詳解C#App.config和Web.config加密

    本篇文章給大家分享了C#App.config和Web.config加密的相關(guān)知識(shí)點(diǎn)以及具體代碼步驟,有興趣的朋友參考學(xué)習(xí)下。
    2018-05-05
  • c#實(shí)現(xiàn)ini文件讀寫(xiě)類(lèi)分享

    c#實(shí)現(xiàn)ini文件讀寫(xiě)類(lèi)分享

    c#實(shí)現(xiàn)ini文件讀寫(xiě)類(lèi)分享,大家參考使用吧
    2013-12-12
  • C# Socket粘包處理講解示例

    C# Socket粘包處理講解示例

    這篇文章主要介紹了C# Socket粘包處理講解,大家可以參考使用
    2013-12-12
  • Winform窗口實(shí)現(xiàn)多顯示屏顯示的2種方法

    Winform窗口實(shí)現(xiàn)多顯示屏顯示的2種方法

    這篇文章主要介紹了Winform窗口實(shí)現(xiàn)多顯示屏顯示的2種方法,本文直接給出了實(shí)現(xiàn)代碼,并對(duì)其中的一些重要參數(shù)做了解釋,需要的朋友可以參考下
    2015-06-06
  • C# DataGridView添加新行的2個(gè)方法

    C# DataGridView添加新行的2個(gè)方法

    DataGridView控件在實(shí)際應(yīng)用中非常實(shí)用,特別需要表格顯示數(shù)據(jù)時(shí)。
    2013-03-03

最新評(píng)論