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