zoukankan      html  css  js  c++  java
  • ASP.Net 反射显示

    //获取泛型T的类型
                        Type type = typeof(T);

                        //循环获取到的数据的行
                        for (int i = 0; i < dt.Rows.Count; i++)
                        {
                            //实例化获取到的类
                            object obj = Activator.CreateInstance(type);

                            //循环获取到的数据的列
                            for (int j = 0; j < dt.Columns.Count; j++)
                            {
                                //获取列的名称
                                PropertyInfo pinfo = type.GetProperty(dt.Columns[j].ColumnName);

                                #region 判断获取到的列的类型
                                //int类型
                                if (dt.Columns[j].DataType == typeof(Int32))
                                {
                                    //判断是否是空值
                                    if (dt.Rows[i][j] != null)
                                    {
                                        pinfo.SetValue(obj, int.Parse(dt.Rows[i][j].ToString(), null));
                                    }
                                    else
                                    {
                                        pinfo.SetValue(obj, 0, null);
                                    }
                                }

                                //float类型
                                if (dt.Columns[j].DataType == typeof(float))
                                {
                                    //判断是否是空值
                                    if (dt.Rows[i][j] != null)
                                    {
                                        pinfo.SetValue(obj, float.Parse(dt.Rows[i][j].ToString(), null));
                                    }
                                    else
                                    {
                                        pinfo.SetValue(obj, 0.0f, null);
                                    }
                                }

                                //datetime类型
                                if (dt.Columns[j].DataType == typeof(DateTime))
                                {
                                    //判断是否是空值
                                    if (dt.Rows[i][j] != null)
                                    {
                                        pinfo.SetValue(obj, DateTime.Parse(dt.Rows[i][j].ToString(), null));
                                    }
                                    else
                                    {
                                        pinfo.SetValue(obj, "", null);
                                    }
                                }

                                //double类型
                                if (dt.Columns[j].DataType == typeof(double))
                                {
                                    //判断是否是空值
                                    if (dt.Rows[i][j] != null)
                                    {
                                        pinfo.SetValue(obj, double.Parse(dt.Rows[i][j].ToString(), null));
                                    }
                                    else
                                    {
                                        pinfo.SetValue(obj, 0.00, null);
                                    }
                                }

                                //string类型
                                if (dt.Columns[j].DataType == typeof(string))
                                {
                                    //判断是否是空值
                                    if (dt.Rows[i][j] != null)
                                    {
                                        pinfo.SetValue(obj, dt.Rows[i][j].ToString(), null);
                                    }
                                    else
                                    {
                                        pinfo.SetValue(obj, "", null);
                                    }
                                }
                                #endregion
                            }

                            list.Add((T)obj);
                        }
                    }
                }
                return list;

  • 相关阅读:
    VS2010引用App_Code下的类文件问题解决方法
    Sql server 2008 sa用户开启教程
    ASP.NET中App_Code,App_Data等文件夹的作用
    错误提示: (provider: Named Pipes Provider, error: 40 Could not open a connection to SQL Server)
    treeview展开一个节点就关闭其他节点
    ASP.NET AJAX Toolkit的安装过程
    c++推荐读物
    for()的多参数
    模板函数I n p u t
    这次真的是下定决心了
  • 原文地址:https://www.cnblogs.com/XJNB/p/13150339.html
Copyright © 2011-2022 走看看