using System;
using System.Collections.Generic;
using System.Text;
using System.Drawing.Printing;
using System.Drawing;
using System.Windows.Forms;
using System.Windows;
using System.Data;
using Microsoft.Office;
namespace KingBoy
{
    class MyDataGrid:DataGridView
    {
        #region var
        //用户可自定义 
        private Font tableFont=new Font("宋体", 9);  // '当前要打印文本的字体及字号 
        private Font headFont=new Font("黑体", 12, FontStyle.Regular);//表头字体 
        private Font subHeadFont=new Font("楷体_GB2312", 10, FontStyle.Regular); //副表头字体 
        private String headText="" ; //表头文字 
        private String subHeadLeftText="";  //副表头左文字
        private String subHeadRightText="";  //副表头右文字 
        private int headHeight=40;  //表头高度 
        private int subHeadHeight=30;  //副表头高度 
        private Font footFont=new Font("黑体", 12, FontStyle.Underline); //表脚字体
        private Font subFootFont=new Font("楷体_GB2312", 10, FontStyle.Regular);//副表脚字体 
        private String footText=""; ////表脚文字 
        private String subFootLeftText="" ;  //副表脚左文字 
        private String subFootRightText="" ;  //副表脚右文字
        private int footHeight=40; //表脚高度
        private int subFootHeight=30;  //副表脚高度 
        private String worker="";  //'制表人
        private double sum=0; //汇总数据
        private int x_unit=0; //表的基本单位
        private int y_unit= 24;

//以下为模块内部使用      
        private PrintDocument printDocument1;     
        private DataRow dataGridRow;
        private DataTable dataTable1;
        private int Cols; //                          '当前要打印的列                          
        private int ColsCount; //                    '当前DATAGRID共有多少列       
        private int pageRecordNumber; //                 '当前要所要打印的记录行数,由计算得到. 
        private int printingPageNumber=0;//           '正要打印的页号 
        private int pageNumber;//                       '共需要打印的页数
        private int printRecordLeave;//                 '当前还有多少页没有打印 
        private int printRecordComplete=0;  //        '已经打印完的记录数 
        private int pLeft,pTop,pRight,pBottom,pWidth,pHeight;
        private SolidBrush drawBrush = new SolidBrush(System.Drawing.Color.Black);//   '当前画笔颜色 
        private int pRecordNumber=0  ;//'每页打印的记录条数 
        private int totalPage;  //总共应该打印的页数        
        #endregion
        #region property
         
        /// <summary>
        ///用户自定义字体及字号
        /// </summary>
        public Font setTableFont
        {
         set{tableFont=value;}
        }
        /// <summary>
        /// 设置表头字体
        /// </summary>
       public Font setHeadFont
       {
        set{headFont =value;}
       }
        public Font setFootFont
        {
         set{footFont=value;}
        }
       public Font setSubFootFont
       {
        set{subFootFont =value;}
       }
      public string setHeadText
      {
       set{headText =value;}
      }
      public string setSubHeadLeftText
      {
        set{subHeadLeftText =value;}
      }
        public string setSubHeadRightText
        {
         set{subHeadRightText =value;}
        }
       public string setFootText
       {
         set{footText =value;}
       }

public string setSubFootLeftText
       {
         set{subFootLeftText =value;}
       }
       public string setSubFootRightText
       {
         set{subFootRightText =value;}
       }
       public int setHeadHeight
       {
        set{headHeight =value;}
       }
public int setSubHeadHeight
{
 set{
   subHeadHeight =value;
 }
}
        public int setFootHeight
        {
         set{footHeight =value;}
        }
       public int setSubFootHeight
       {
         set{subFootHeight =value;}
       }
        public int setCellHeight
        {
          set{y_unit =value;}
        }
        /// <summary>
        /// 汇总数据
        /// </summary>
        public double setSum
        {
         set{sum=value;}
        }
        /// <summary>
        /// 设置制表人
        /// </summary>
      public string setWorker
      {
       set{worker =value;}
      }
       
        #endregion
        #region method
        /// <summary>
        /// 根据列明统计该列值总和
        /// </summary>
        /// <param name="colomnName">列明</param>
        /// <returns>如果该列明是数值型,则返回统计结果,否则返回0</returns>
        public double addColumnDGV(string colomnName)
        {
          try
          {
              int i=0; //循环下标
              double sum=0;//用来保存统计临时结果
              for(i=0;i<this.Rows.Count ;i++)
                  try
                  { sum=sum+Convert.ToDouble(this.Rows[i].Cells[colomnName].Value); }//获取i行colomnName列值
                  catch (Exception)
                  { }                  
              return sum;
          }
            catch(Exception )
          {
            return 0;
            }
        }
        public double addColumnDGV(string colomnName,char ch)
        {
            try
            {
                int i = 0; //循环下标
                double sum = 0;//用来保存统计临时结果
                for (i = 0; i < this.Rows.Count; i++)
                    try
                    { sum = sum + Convert.ToDouble(this.Rows[i].Cells[colomnName].Value.ToString().Substring(1, this.Rows[i].Cells[colomnName].Value.ToString().Length-1)); }//获取i行colomnName列值
                    catch (Exception)
                    { }
                return sum;
            }
            catch (Exception)
            {
                return 0;
            }
        }
        /// <summary>
        /// 统计某行从intStartCol列到intEndCol和
        /// </summary>
        /// <param name="row">行值</param>
        /// <param name="intStartCol">起始列索引值</param>
        /// <param name="intEndCol">终止列索引值</param>
        /// <returns>合法统计结果,非法返回0</returns>
        public double addRowDGV(int row,int intStartCol,int intEndCol)
        {
          try
          {
              //判断列的起始和终止索引是否有效,行值在有效的范围内
            if (this.Columns.Count >0 && intStartCol >=0 && intEndCol <this.Columns.Count && row<this.Rows.Count ) 
            {
              int i;
                double tmpDec=0;
                //循环统计该行起始列到终止列累加和,从intStartCol到intEndCol列都是数值型数据
                for (i=intStartCol;i<intEndCol;i++)
                    try
                    {tmpDec=tmpDec +(double)(this.Rows[row].Cells[i].Value); }
                    catch (Exception)
                    { }
                    
                return tmpDec;
            }
            else
                return 0;
          }
            catch(Exception)
          {
            return 0;
            }
        }    
        /// <summary>
        /// 导出数据到Excel
        /// <param name="startComlumn">起始列,0表示第一列,依次类推</param>
        /// <param name="endColumn" >终止列,1表示第一列,依次类推</param>
        /// </summary>
        public void loadDataToExcel(int startComlumn,int endColumn)
        {
          if (this.Rows.Count <=0)
          { MessageBox.Show("没有数据,无法导出!");
            return ;
          }
          if (startComlumn > endColumn)
          {
              MessageBox.Show("起始列不能大于终止列!");
              return;
          }
          if (startComlumn>=this.Columns.Count || endColumn>=this.Columns.Count)
          {
              MessageBox.Show("起始列和终止列都不能大于总列数!");
              return;
          }
          //创建Excel中的新表         
          Excel.ApplicationClass oExcel = new Excel.ApplicationClass();
          oExcel.Application.Workbooks.Add(true);   
          
          int n=0;
          int i=0;         
          //填充表头
          for (i = startComlumn; i < endColumn; i++)
          { 
          oExcel.Cells[1, i+1] = this.Columns[i].HeaderText;
          }
          for(n=0;n<this.Rows.Count;n++)
              for (i = startComlumn; i <endColumn; i++)
              { 
               oExcel.Cells[n+2, i+1] = this.Rows[n].Cells[i].Value.ToString();
             
              }
          oExcel.Visible = true;        
          oExcel.Quit();
          oExcel = null;
            GC.Collect();
              
        }

含有打印、统计DataGridView(1)的更多相关文章

  1. 含有打印、统计DataGridView(2)

    /// <summary>        /// 导出数据到Excel                /// </summary>        public void loa ...

  2. C语言字母频率统计

    在进行密码破解时有时候需要得到字母出现的频率信息,下面我将简单的使用C语言来读取一个文件,然后统计该文件内的字母出现的频率. 1.在D盘下新建一个文本文件(文件名为"A.txt") ...

  3. Linux - wc统计文件行数、单词数或字节数

    一 wc简单介绍 wc命令用来打印文件的文本行数.单词数.字节数等(print the number of newlines, words, and bytes in files).在Windows的 ...

  4. shell的wc命令统计 head tail命令详解

    Linux系统中的wc(Word Count)命令的功能为统计指定文件中的字节数.字数.行数,并将统计结果显示输出. 1.命令格式: wc [选项]文件... 2.命令功能: 统计指定文件中的字节数. ...

  5. C# 使用PrintDocument 绘制表格 完成 打印预览

    C# 使用PrintDocument 绘制表格 完成 打印预览 DataTable   经过不断的Google与baidu,最终整理出来的打印类 主要是根据两个参考的类组合而成,稍微修改了一下,参考代 ...

  6. C# 使用PrintDocument 绘制表格 完成 打印预览 DataTable

    经过不断的Google与baidu,最终整理出来的打印类 主要是根据两个参考的类组合而成,稍微修改了一下,参考代码及来源见最后(其中一份是VB语言的) 其中遇到的一些问题也已经得到了解决(分页,打印预 ...

  7. C# WinForm开发系列 - DataGrid/DataGridView

    在WinForm开发中,DataGrid/DataGridView被广泛使用于绑定数据库中数据进行呈现.整理一些关于DataGrid/DataGridView使用的文章,涉及DataGrid/Data ...

  8. Linux命令-统计文件中的字节数、字数、行数:wc

    Linux系统中的wc(Word Count)命令的功能为统计指定文件中的字节数.字数.行数,并将统计结果显示输出. 1.命令格式: wc [选项]文件... 2.命令功能: 统计指定文件中的字节数. ...

  9. C# PrintDocument 打印表格

    1.封装好的辅助类: using System; using System.Data; using System.Drawing; using System.Drawing.Printing; usi ...

随机推荐

  1. 如何查看 Linux 中所有正在运行的服务

    有许多方法和工具可以查看 Linux 中所有正在运行的服务.大多数管理员会在 System V(SysV)初始化系统中使用 service service-name status 或 /etc/ini ...

  2. HttpClient方式调用接口的java 简单案例源码+附jar包

    1 package com.itNoob.httpClient; import org.apache.commons.httpclient.HttpClient; import org.apache. ...

  3. java设计模式--事件监听器模式和观察者模式

    监听器模式:事件源经过事件的封装传给监听器,当事件源触发事件后,监听器接收到事件对象可以回调事件的方法 观察者模式:观察者(Observer)相当于事件监听者,被观察者(Observable)相当于事 ...

  4. 20160227.CCPP体系具体解释(0037天)

    程序片段(01):01.一对一模式.c+02.中介者模式.c+03.广播模式.c 内容概要:事件 ///01.一对一模式.c #include <stdio.h> #include < ...

  5. Java 实现策略(Strategy)模式

    策略模式:行为型模式 将同一行为,不同的处理算法分别封装起来.让它们之间能够互相替换 1. 定义一个超类型接口,及 行为方法 2. 定义不同的实现类,实现该行为的 不同的算法 /** * 策略模式:针 ...

  6. jquery源码09 (6058 , 6620) css() : 样式的操作

    var curCSS, iframe, // swappable if display is none or starts with table except "table", & ...

  7. 【基础篇】DatePickerDialog日期控件的基本使用(一)

    项目步骤: 1.首先在Main.xml布局文件中添加一个Button标签,用来点击显示日期控件,Main.xml内容如下: <RelativeLayout xmlns:android=" ...

  8. CHARINDEX,REPLACE,LEFT+四大系统函数+模糊查询

    select CHARINDEX('bob','my name is bob',1)--返回12  bob的第一个b在字符串中排第12(从1开始数) select CEILING(456.4)--45 ...

  9. LuoguP4016 负载平衡问题(费用流)

    题目描述 G 公司有 n 个沿铁路运输线环形排列的仓库,每个仓库存储的货物数量不等.如何用最少搬运量可以使 n 个仓库的库存数量相同.搬运货物时,只能在相邻的仓库之间搬运. 输入输出格式 输入格式: ...

  10. 热点共享SS网络

    # 测试系统: Ubuntu 16.04 LTS-lxde-ARM # ***-libev 安装脚本源于 秋水逸冰: https://teddysun.com/358.html # ss-tproxy ...