本篇把项目中用到的一些通用方法总结出来, 这些方法因为经常需要在项目中用到,所以把它们归纳在一起, 形成一个.dll 文件是一个理想的选择. 这样也便于日后缩短开发周期.
 
一. 把一个DataGridView对象转换成一个DataTable对象
 public static DataTable GetDgvToTable(DataGridView dgv)
   {
           if(dgv==null) throw new NullReferenceException();
            DataTable dt = new DataTable();
            for (int count = 0; count < dgv.Columns.Count; count++)  //遍历DataGridView每一列
            {
                DataColumn _column = new DataColumn(dgv.Columns[count].Name.ToString()); //根据DataGridView每一列创建一个列对象
                dt.Columns.Add(_column); //添加列
            }  
           for (int count = 0; count < dgv.Rows.Count; count++)    //遍历DataGridView没一行
            {
                DataRow dr = dt.NewRow();
                for (int col = 0; col < dgv.Columns.Count; col++)
                {
                    dr[col] = dgv.Rows[count].Cells[col].Value == null ? "" : dgv.Rows[count].Cells[col].Value.ToString();
                }
                dt.Rows.Add(dr); //添加行
            }
            return dt;
        }
 
2. 给DataTable添加合计行
 public static DataTable AddCountRow(DataTable dt, int[] index)
     {
            if (dt.Rows.Count > 0)
            {
                DataRow row = dt.NewRow();
                row[0] = "合计:";
                row[1] = dt.Rows.Count + "";
                for (int i = 0; i < index.Length; i++) //遍历需要合计的行
                {
                    for (int j = 0; j < dt.Columns.Count; j++) //遍历DataTable每一列
                    {
                        int columnIndex = 0;
                        if (index == j) //找到第一个要合计的列
                        {
                            columnIndex = index; //合计列索引
                            string columname = dt.Columns[columnIndex].ColumnName; //要合计列的名称
                            if (string.IsNullOrEmpty(dt.Compute("sum(" + columname + ")", "true").ToString())) //判断是否为空
                                row[columnIndex] = 0.00;
                            else
                                row[columnIndex] = decimal.Parse(dt.Compute("sum(" + columname + ")", "true").ToString());  //得到合计列的结果
                            break;
                        }
                    }
                }
                dt.Rows.Add(row);
            }
            return dt;
        }

 
3. 将DataTable数据集映射到实体对象
  public static List<TResult> TableToObject<TResult>(DataTable dt, TResult ob) //泛型方法,此处TResult为类型参数
        {
            List<PropertyInfo> prlist = new List<PropertyInfo>();//创建一个属性列表集合

Type t = typeof(TResult); //获取实体对象的元数据Type类型

PropertyInfo[] prArr = t.GetProperties(); //取得实体对象的所有属性到属性集合中

foreach (PropertyInfo pr in prArr) //循环遍历属性集合到List集合
                prlist.Add(pr);
            //通过匿名方法自定义筛选条件  => 检查datatable中是否存在存在此列, 
            Predicate<PropertyInfo> prPredicate = delegate(PropertyInfo pr) { if (dt.Columns.IndexOf(pr.Name) != -1) return true; return false; };
            //从指定的条件中
           List<PropertyInfo> templist = prlist.FindAll(prPredicate);
           //创建一个实体集合
            List<TResult> oblist = new List<TResult>();
           //遍历DataTable每一行
            foreach (DataRow row in dt.Rows)
            {
                ob = (TResult)Activator.CreateInstance(t);  //通过Type类型创建对象,并强制转换成实体类型
                Action<PropertyInfo> prAction = delegate(PropertyInfo pr) {if(row[pr.Name] != DBNull.Value) pr.SetValue(ob, row[pr.Name], null); };
                 //把选择出来的属性集合的每一个属性设置成上面创建的对象的属性
                templist.ForEach(prAction);
                oblist.Add(ob); //把属性添加到实体集合
            }
            return oblist;
        }
 
4. 将一个DataTable导出到Excel中
// 参数依次为报表标题, 数据集
 public static void ExportExcel(string p_ReportName, DataTable dt)
        {
            string saveFileName = "";
            bool fileSaved = false;
            SaveFileDialog saveDialog = new SaveFileDialog();
            saveDialog.DefaultExt = "xls";
            saveDialog.Filter = "Excel文件|*.xls";
            saveDialog.FileName = "Sheet1";
            saveDialog.ShowDialog();
            saveFileName = saveDialog.FileName;
            if (saveFileName.IndexOf(":") < 0) return; //被点了取消

// 创建Excel对象                   
            Excel.Application xlApp = new Excel.ApplicationClass();
            if (xlApp == null)
            {
                MessageBox.Show("Excel无法启动");
                return;
            }
            // 创建Excel工作薄
            Excel.Workbook xlBook = xlApp.Workbooks.Add(true);
            Excel.Worksheet xlSheet = (Excel.Worksheet)xlBook.Worksheets[1];
            // 设置标题
            Excel.Range range = xlSheet.get_Range(xlApp.Cells[1, 1], xlApp.Cells[1, dt.Columns.Count]);
            //Excel.Range range = xlSheet.get_Range(xlApp.Cells[1, 1], xlApp.Cells[1, m_dt.Columns.Count]);
            range.MergeCells = true;
            xlApp.ActiveCell.FormulaR1C1 = p_ReportName;
            xlApp.ActiveCell.Font.Size = 20;
            xlApp.ActiveCell.Font.Bold = true;
            xlApp.ActiveCell.HorizontalAlignment = Excel.Constants.xlCenter;
            // 列索引,行索引,总列数,总行数
            int colIndex = 0;
            int RowIndex = 0;
            int colCount = dt.Columns.Count;
            int RowCount = dt.Rows.Count - 1;//this.BindingContext[this.DataSource, this.DataMember].Count;
            // 创建缓存数据
            object[,] objData = new object[RowCount + 1, colCount];
            // 获取列标题
            foreach (DataColumn cs in dt.Columns)
            {
                objData[RowIndex, colIndex++] = cs.ColumnName;
            }
            // 获取数据
            for (RowIndex = 1; RowIndex < RowCount; RowIndex++)
            {
                for (colIndex = 0; colIndex < colCount; colIndex++)
                {
                    objData[RowIndex, colIndex] = dt.Rows[RowIndex][colIndex];//this[RowIndex - 1, colIndex];
                }
                Application.DoEvents();
            }
            // 写入Excel
            range = xlSheet.get_Range(xlApp.Cells[2, 1], xlApp.Cells[RowCount, colCount]);
            range.Value2 = objData;
            // 保存
            try
            {
                xlBook.Saved = true;
                xlBook.SaveCopyAs(saveFileName);
                MessageBox.Show("导出成功!");
            }
            catch
            {
                MessageBox.Show("保存出错,请检查!");
                return;
            }
            finally
            {
                xlApp.Quit();
                GC.Collect();
            }
            return;
        }
5. 通过字典缓存一些不变的本地数据集
//声明一个字典集合
  private static Dictionary<string, object> dicObject = new Dictionary<string, object>();
//下面缓存某个数据集
  public static DataTable GetCustomers(string custup)
        {
            DataTable dt;
            string key = "AllCustomers" + custup;
            if (dicObject.ContainsKey(key))
            {
                dt = (DataTable)dicObject[key];
            }
            else
            {
                dt = BasicInfo.GetCustomers(custup).Tables[0];
                dicObject.Add(key, dt);
            }
            return dt;
        }

项目中常用方法总结(将将DataTable数据集映射到实体对象)【转】的更多相关文章

  1. 为什么在项目中data需要使用return返回数据呢?

    问:为什么在项目中data需要使用return返回数据呢? 答:不使用return包裹的数据会在项目的全局可见,会造成变量污染:使用return包裹后数据中变量只在当前组件中生效,不会影响其他组件.

  2. 导出Excel文件(项目中会遇到很多将一些数据导出Excel或者et)

    最近在项目中,遇到一些需求,就是将数据导出来,以Excel文件为主:就自己简单的做一些demo:供初学者来学习: // 定义一个保存文件的路径位置 SaveFileDialog dlgPath = n ...

  3. 一个Web项目中实现多个数据库存储数据并相互切换用过吗?

    最近公司一个项目需要连接多个数据库(A和B)操作,根据不同的业务模块查询不同的数据库,因此需要改造下之前的spring-mybatis.xml配置文件以及jdbc.properties配置文件,项目后 ...

  4. 项目中整合第三方插件与SpringMVC数据格式化关于ip地址

    一.Bootstrap 响应式按钮 <div calss="col-sm-2"> <button class="btn btn-default btn- ...

  5. 项目中简单使用ztree,简单数据。

    由于公司架构较旧,使用的jdk版本为1.4,页面上也没有el表达式. 加入 js 文件 <% String context = request.getContextPath(); %> & ...

  6. vue项目中使用mockjs+axios模拟后台数据返回

    自己写练手项目的时候常常会遇到一个问题,没有后台接口,获取数据总是很麻烦,于是在网上找了下,发现一个挺好用的模拟后台接口数据的工具:mockjs.现在把自己在项目中使用的方法贴出来   先看下项目的目 ...

  7. 关于Servo项目中Rust代码行数的数据来源

    我两个月之前的一篇博客<为什么我说Rust是靠谱的编程语言>(下面简称原文),在当中"6. 两个半大型成功案例"一节.我以前写道: Servo: 下一代浏览器渲染引擎( ...

  8. MongoDB项目中常用方法

    使用MongoDB连接池MongoOptions来进行连接 以及相关方法的调用 //获得驱动地址(这里的驱动 写入了配置文件中) String serverAddressStr = Configure ...

  9. vue项目中使用mockjs模拟接口返回数据

    Mock.js 是一个模拟数据生成器,利用它,可以拦截ajax请求,直接模拟返回数据,这样前后端只要约定好数据格式,前端就不需要依赖后端的接口,可以直接使用模拟的数据了. 网上介绍mock的教程也较多 ...

随机推荐

  1. mongodb导入导出备份恢复

    mongodb数据库同样离不开必要的维护,如备份.恢复.导入.导出. 其实备份和恢复比导入和导出要方便些,而且一般不会出错,所以大部分时候使用备份和恢复操作就可以了 1. 备份Mongodb mong ...

  2. AC大牛经典语录

    超经典:     1. 为了世界的和平,为了女生的安全,我拼命做题,做题,做题! 2. A ac a day, keeps the doctor away! 3. from good to great ...

  3. Unity 人物跟谁手指的移动(第一种方式)

    长夜漫漫无心睡眠,敲敲代码,越敲越来劲! 我发现好多小朋友都在玩熊出没之xxxx这个游戏,居然打了一下午都没玩通第2关,我把测试也叫来陪我一起玩! 结果他也打不通,我再去叫策划,他也没打过,我去叫主管 ...

  4. HDU 4521 间隔》=1的LIS 线段树+dp

    九野的博客,转载请注明出处:http://blog.csdn.net/acmmmm/article/details/11991119 题意: n个数 d个距离 下面n个数的序列,求序列中的最长单调递增 ...

  5. UNIX环境高级编程--高级I/O(三)

    一.高级I/O 包括非阻塞I/O.记录锁.系统V流机制.I/O多路回转(select和poll函数).readv和writev函数以及存储映射I/O(mmap),这些都是高级I/O.    其实在上面 ...

  6. Jquery ui datepicker 设置日期范围,如只能隔3天

    最近的后台项目前端使用了jquery ui 日历控件自然就使用了jquery ui 的   datepicker 后台数据比较好大,一般是千万级的和百万级的关联,查询会很慢,所以后加想多加些过滤条件, ...

  7. MySQL ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO

    MySQL安装完server端和客户端后,登录Mysql时报错:[root@rhel204 MySQL 5.6.23-RMP]# mysqlERROR 2002 (HY000): Can't conn ...

  8. Mongoose的使用

    最近想做一个练手的App小项目.考虑到数据接口的问题,因为关系型数据库用的比较多,也有一定经验了,所以打算使用比较火的MongoDB作为数据库,下面就介绍一下Mongoose的使用方法吧. 概念:Mo ...

  9. 我们为什么要遵循W3C标准规范

    大部分的站长和拥有网站的企业负责人都会知道,每当有浏览器发布大更新的时候,我们刚建立不久的网站就会发生无法预知的严重错误,我们只能重新建立或改版网站,使其可以应归新发布的浏览器.好比1996-1999 ...

  10. C/c++几个预定义的宏:__DATE__,__TIME__,__FILE__,__LINE__

    一边情况下,C/C++编译器会内置几个宏,这些宏定义不仅可以帮助我们完成跨平台的源码编写,灵活使用也可以巧妙地帮我们输出非常有用的调试信息. ANSI C标准中有几个标准预定义宏(也是常用的): __ ...