使用C#和Excel进行报表开发(三)-生成统计图(Chart)1

来源:互联网 发布:禁止用户安装软件 编辑:程序博客网 时间:2024/06/05 07:43

有的Web项目选用Excel作为报表方案,在服务器端生成Excel文件,然后传送到客户端,由客户端进行打印。在国内的环境下,相对PDF方式,Excel的安装率应该比pdf阅读器的安装率要高,同时,微软也为C#操作Excel提供了完备的接口,虽然ZedGraph和其他的商业报表工具生成的统计图也很好,但是人家微软毕竟是大品牌,值得信赖。

本文介绍使用C#调用Excel来生成统计图(Chart)的以及Chart图中各部分控制的一些方法。

 

在上一篇使用C#Excel进行报表开发(二)-操作统计图(Chart中,我们使用一个预定义的Excel文件,通过改变Chart中的某个值来生成统计图。本文进一步演示如何从指定的数据从头生成统计图。

 

首先当然要添加对Excel的引用,然后需要定义几个要用到的Excel对象:

Excel.Application ThisApplication = null;

Excel.Workbooks m_objBooks = null;

Excel._Workbook ThisWorkbook = null;

Excel.Worksheet xlSheet = null;

 

在创建一个新的_WorkBook对象的时候,默认的会含有3Sheet,所以为了显示清晰,将多余的Sheet都删掉:

private void DeleteSheet()

{

        foreach (Excel.Worksheet ws in ThisWorkbook.Worksheets)

                if (ws != ThisApplication.ActiveSheet)

                {

                        ws.Delete();

                }

        foreach (Excel.Chart cht in ThisWorkbook.Charts)

                cht.Delete();

                       

}

 

再下来需要添加用来给Chart提供数据的Sheet

private void AddDatasheet()

{

        xlSheet = (Excel.Worksheet)ThisWorkbook.

                Worksheets.Add(Type.Missing, ThisWorkbook.ActiveSheet,

                Type.Missing, Type.Missing);

 

        xlSheet.Name = "数据";

}

 

生成Chart用到的数据,因为是演示,所以这里使用生成随机数的方法来替代从数据库中提取数据。

private void LoadData()

{

        Random ran = new Random();

        for (int i = 1; i <= 12; i++)

        {

                xlSheet.Cells[i,  1] = i.ToString() + "";

                xlSheet.Cells[i, 2] = ran.Next(2000).ToString();       

        }

}

 

 

原创粉丝点击