欢迎来到代码驿站!

.NET代码

当前位置:首页 > 软件编程 > .NET代码

c#中DataTable转List的2种方法示例

时间:2022-02-16 10:45:00|栏目:.NET代码|点击:

在项目中常常常使用到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#利用PrintDocument定制打印单据的小例子

栏    目:.NET代码

下一篇:VS2017 安装打包插件的图文教程

本文标题:c#中DataTable转List的2种方法示例

本文地址:http://www.codeinn.net/misctech/193586.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有