首页 > 软件编程 > C#教程 > C#泛型与DataTable互转

C#中泛型举例List<T>与DataTable相互转换

作者:springsnow

这篇文章介绍了C#中泛型举例List<T>与DataTable相互转换的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

一、 DataTable转换到List<T>

/// <summary>   
/// TableToList   
/// </summary> 
public class TableListConverter<T> where T : class, new()
    public static IList<T> TableToList(DataTable dt)
        IList<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;
                if (dt.Columns.Contains(tempName))// 检查DataTable是否包含此列
                    if (!pi.CanWrite) continue;// 判断此属性是否有Setter
                    object value = dr[tempName];
                    if (value != DBNull.Value)
                        pi.SetValue(t, value, null);
            ts.Add(t);
        return ts;
// 获得查询结果 
DataTable dt = DbHelper.ExecuteDataTable("...");
// 把DataTable转换为IList<UserInfo> 
IList<UserInfo> users = TableListConverter<UserInfo>.TableToList(dt);

二、 List<T>转换到DataTable

/// <summary>   
/// ListToTable   
/// </summary>   
public class TableListConverter
    public static DataTable ListToTable<T>(IList<T> list) where T : class, new()
        if (list == null) return null;
        Type type = typeof(T);
        DataTable dt = new DataTable();
        PropertyInfo[] properties = Array.FindAll(type.GetProperties(), p => p.CanRead);//判断此属性是否有Getter
        Array.ForEach(properties, prop => { dt.Columns.Add(prop.Name, prop.PropertyType); });//添加到列
        foreach (T t in list)
            DataRow row = dt.NewRow();
            Array.ForEach(properties, prop =>
                row[prop.Name] = prop.GetValue(t, null);
            });//添加到行
            dt.Rows.Add(row);
        return dt;
//IList<UserInfo> users 
DataTable dt =TableListConverter.ListToTable(users)

到此这篇关于C#中泛型举例List<T>与DataTable相互转换的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • C#结合JavaScript实现上传视频到腾讯云点播平台的操作方法
    C#结合JavaScript实现上传视频到腾讯云点播平台的操作方法
    2023-11-11
  • C#调用FFplay实现播放视频功能
    C#调用FFplay实现播放视频功能
    2023-10-10
  • C#使用OpenCvSharp实现透视变换功能
    C#使用OpenCvSharp实现透视变换功能
    2023-11-11
  • C#实现块状链表的项目实践
    C#实现块状链表的项目实践
    2023-11-11
  • C# 泛型编译特性对性能的影响小结
    C# 泛型编译特性对性能的影响小结
    2023-11-11
  • C#使用NPOI操作Excel工具类的实现
    C#使用NPOI操作Excel工具类的实现
    2023-11-11
  • 基于C#编写获取硬件信息的工具类
    基于C#编写获取硬件信息的工具类
    2023-11-11
  • C#实现微信退款及对账功能的示例详解
    C#实现微信退款及对账功能的示例详解
    2023-11-11
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2024 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号