• c# 构建一个DataTable数据集并把它转化为相应的类集合


    示例:

            public void test()
            {
                DataTable dtz = new DataTable();
                //添加Table中的列
                DataColumn dc1 = new DataColumn("UserName", Type.GetType("System.String"));
                DataColumn dc2 = new DataColumn("IDType", Type.GetType("System.String"));
                DataColumn dc3 = new DataColumn("IDCardNo", Type.GetType("System.String"));
                DataColumn dc4 = new DataColumn("SalaryAmount", Type.GetType("System.String"));
                dtz.Columns.Add(dc1);
                dtz.Columns.Add(dc2);
                dtz.Columns.Add(dc3);
                dtz.Columns.Add(dc4);
                //以上代码完成了DataTable的构架,但是里面是没有任何数据的
                for (int i = 0; i < 10; i++)
                {
                    DataRow dr = dtz.NewRow();
                    dr["UserName"] = "James"+i;
                    dr["IDType"] = "1";
                    dr["IDCardNo"] = "34212419800606" + i;
                    dr["SalaryAmount"] = "5000";
                    dtz.Rows.Add(dr);
                }
                var excelList = ModelConvertHelper<HRImportSalaryExcel>.ConvertToModel(dtz);
    
            }

    定义一个类:

    public class HRImportSalaryExcel
        {
            /// <summary>
            /// 姓名    
            /// </summary>
            public string UserName { get; set; }
            /// <summary>
            /// 证件类型   1- 身份证;2-护照;
            /// </summary>
            public string IDType { get; set; }
            /// <summary>
            /// 证件号码    
            /// </summary>
            public string IDCardNo { get; set; }
            /// <summary>
            /// 应发工资金额 
            /// </summary>
            public string SalaryAmount { get; set; }
    }

    DataTable转换为List

    /// <summary>    
        /// 实体转换辅助类 DataTable转换到List  
        /// 使用方式
        ///把DataTable转换为IList<UserInfo>  
        ///IList<UserInfo> users = ModelConvertHelper<UserInfo>.ConvertToModel(dt);
        /// </summary>    
        public class ModelConvertHelper<T> where T : new()
        {
            public static List<T> ConvertToModel(DataTable dt)
            {
                // 定义集合    
                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;
            }
        }
  • 相关阅读:
    Django 项目试炼blog(8) -- 评论树的显示
    Django 项目试炼blog(7) -- 文章详情页2 -- 前端样式的继承与楼评论显示
    Django 项目试炼blog(6) -- 文章详情页1 -- 点赞功能
    Django 项目试炼blog(5) -- 个人站点的搭建
    Django 项目试炼blog(4)--blog主页的搭建以及admin的使用
    Django 项目试炼blog(3)--基于Form组件ajax用户注册
    Django 项目试炼blog(2)--用户登陆验证
    Django 项目试炼blog(1)
    Django 基于form与ajax发送文件
    Django 分页器制作
  • 原文地址:https://www.cnblogs.com/firstcsharp/p/16361412.html
Copyright © 2020-2023  润新知