说明:这是一个实验的小例子,在实际项目中使用时,一般Object[,] 对象的数据来源于数据库。

1. 实验环境

开发平台:Visual Studio 2010

测试模板:JBtest

Excel:Office2007 Excel

2. 项目所用组件

为什么选择ASP.NET做打印的功能,因为office和Visual  studio同是微软的开发软件,具有良好的兼容性,利用上述.dll组件,可以轻松实现excel模板的导入和excel数据的导出。

ExcelQuicker.dll动态链接库需要在网上下载,引用到项目中才可以使用。我用的这个版本比较早,版本号是2.2.0.0。现在的更新版本可能修改了一些函数和类的名称,请参考后使用。

3. webconfig配置

4.项目结构

以上是项目的整体结构,其中,测试网页为Default.aspx。Lib目录下的ExcelQuicker.xml为ExcelQuicker组件的配置文档,Message.xml为导入出错时报错的信息。

5.报表打印

首先在实现打印的网页后台引用命名空间:using ExcelQuicker.Framework;

利用ExcelQuicker.Framework空间的相应类提供的接口实现报表的新建

EQApplication objApp = new EQApplication(strFileName, EQReportFormat.Excel, strTemplate, false);

EQWorksheet objWS = new EQWorksheet("报表数据");

数据写入到excel文档里类似于VBA编程,具体细节功能请参考代码:Default.aspx.cs

EQRange range = new EQRange(objData, 11, 5, 15, 5);   //从“11行 5列” 到 “22行  5列”

objWS.Add(range);

Default.aspx.cs后台主要代码:

protected void dy_Click1(object sender, EventArgs e)
        {
            string wjm;
            string strTemplate = "JBtest.xls";//模板文件名称
            Initialize();//调用excel quicker初始化函数
            // string strFileName = Session["yhid"].ToString();
            string strFileName = "wangling";
            wjm = strFileName;
            wjm = wjm + "_" + strTemplate;
            set_Excel(wjm, strTemplate);//生成并设置此excel表
            Response.Redirect("..\\ExcelQuicker\\TempReports\\" + wjm);
        }
        public void Initialize()
        {

EQConfiguration.XmlFileName = HttpRuntime.AppDomainAppPath + "ExcelQuicker\\Lib\\Message.xml";
            EQConfiguration.Language = "EN";
            EQConfiguration.TemporaryFilePath = HttpRuntime.AppDomainAppPath + "ExcelQuicker\\TempReports\\";
            EQConfiguration.OutputFilePath = HttpRuntime.AppDomainAppPath + "ExcelQuicker\\TempReports\\";
            EQConfiguration.TemplateFilePath = HttpRuntime.AppDomainAppPath + "jb\\xls\\";
        }

void set_Excel(string strFileName, string strTemplate)
        {

EQApplication objApp = new EQApplication(strFileName, EQReportFormat.Excel, strTemplate, false);
            EQWorksheet objWS = new EQWorksheet("报表数据");

object[,] objData, objData3, objData4, objData5, objData6, objData7;
            objData = new object[5, 1];//用于存放要填充到Excel中的数据

objData3 = new object[8, 1];

objData4 = new object[1, 1];
            objData5 = new object[3, 1];

objData6 = new object[8, 1];
            objData7 = new object[8, 1];

string ren, ren1, ren2, ren3;
            objData[0, 0] = congye .Text  ;//从业人员期末人数
            objData[1, 0] = guanli .Text ;//单位负责人
            objData[2, 0] = zaigang .Text ;//在岗职工
            objData[3, 0] = laowu .Text ;//劳务派遣人员
            objData[4, 0] =qita0 .Text ;//其他从业人员

ren = "188" + "  人";
            ren1 = "22" + "  人";
            ren2 = "33" + "  人";
            ren3 = "44" + "  人";
            objData4[0, 0] = ren;//直接从事生产经营活动的平均人数
            objData5[0, 0] = ren1;//其中:工程技术人员
            objData5[1, 0] = ren2;//其中:一级建造师
            objData5[2, 0] = ren3;//其中:现场施工人员

EQRange range = new EQRange(objData, 11, 5, 15, 5);   //从“11行 5列” 到 “22行  5列”     
            objWS.Add(range);

EQRange range4 = new EQRange(objData4, 30, 3, 30, 3);   //从“11行 5列” 到 “22行  5列”     
            objWS.Add(range4);
            EQRange range5 = new EQRange(objData5, 32, 6, 34, 6);   //从“11行 10列” 到 “22行  10列”     
            objWS.Add(range5);

objData7[0, 0] = pingjun .Text ;
            objData7[1, 0] =zaigangpj0.Text ;
            objData7[2, 0] = laowupj0.Text ;
            objData7[3, 0] = qitapj.Text ;
            //range7 1-本季 平均人数//
            EQRange range7 = new EQRange(objData7, 16, 5, 19, 5);
            objWS.Add(range7);

objData3[0, 0] =congyeg.Text ;//从业人员工资总额
            objData3[1, 0] = zaizhig.Text  ;//在岗职工工资总额
            objData3[2, 0] = laog .Text ;//劳务派遣人员工资总额
            objData3[3, 0] = qitag.Text ;//其他从业人员工资总额

EQRange range3 = new EQRange(objData3, 21, 5, 24, 5);   //从“11行 10列” 到 “22行  10列”     
            objWS.Add(range3);

objData6[0, 0] = congyepjg.Text ;

objData6[1, 0] = zaigangpjg.Text ;

objData6[2, 0] =laowupjg.Text ;

objData6[3, 0] = qitapjg.Text ;

EQRange range6 = new EQRange(objData6, 25,5,28, 5);
            objWS.Add(range6);

//以下填写报送人员信息
            string ryxx = "单位负责人: " + df.Text + "    统计负责人:" + xf.Text + " 填表人:" + tf.Text;

objData = new object[1, 1];
            objData[0, 0] = ryxx;
            range = new EQRange(objData, 35, 1, 35, 1);
            objWS.Add(range);

//以下填写表头单位名称

objData = new object[1, 1];
            objData[0, 0] = "Excel表格数据导出测试";
            range = new EQRange(objData, 7, 1, 7, 1);
            objWS.Add(range);
            objApp.Add(objWS);

try
            {
                objApp.Output();
            }
            catch (Exception)
            {
                objApp.Dispose();
            }
        }

6. 效果截图

界面上填写数据,把填写的数据导入到对应的excel文档里面

填写数据后,点击导出excel按钮,出现如图界面

打印到Excel后的结果

以上小例子下载:Demo.zip

.NET下Excel报表的打印的更多相关文章

  1. ASP.NET打印EXCEl报表技术总结

    序言:我们在做企业项目或者一些管理系统的时候往往会用到导出到excel报表这项功能,下面我介绍的是用windows自带的excel来打印 首先必须引入:Interop.Excel.dll.Intero ...

  2. 10、借助POI实现Java生成并打印excel报表(1)

    10.1.了解 Apache POI 实际开发中,用到最多的是把数据库中数据导出生成报表,尤其是在生产管理或者财务系统中用的非常普遍.生成报表格式一般是EXCEL或者PDF .利用Apache  PO ...

  3. ASP环境下轻松实现报表的打印 (转)

    作者:zcg2000 一.前言 ASP在电子商务上应用广泛,报表的处理又有一些麻烦.本文介绍了在ASP中利用 本人写的Report Server Page脚本解释器实现报表的显示.打印. 二.准备工作 ...

  4. Java使用POI实现数据导出excel报表

    Java使用POI实现数据导出excel报表 在上篇文章中,我们简单介绍了java读取word,excel和pdf文档内容 ,但在实际开发中,我们用到最多的是把数据库中数据导出excel报表形式.不仅 ...

  5. 关于Web报表FineReport打印的开发应用案例

    报表打印是报表使用和开发过程中经常碰到的问题,这里汇总了关于Web报表开发打印功能的一些典型应用案例,以应用最广泛的FineReport为例. 案例一:java直接调用报表打印 当java后台定义定时 ...

  6. 在.NET中使用EPPlus生成Excel报表 .

    --摘抄自:http://blog.csdn.net/zhoufoxcn/article/details/14112473 在开发.NET应用中可能会遇到需要生成带图表(Chart)的Excel报表的 ...

  7. poi导出Excel报表多表头双层表头、合并单元格

    效果图: controller层方法: /**     *      * 导出Excel报表     * @param request     * @return     *      */    @ ...

  8. C# 对Excel文档打印时的页面设置

    1.对打印页面的朝向,页宽,页高进行设置 参考源码[1] using Excel = Microsoft.Office.Interop.Excel; Excel.Application tmpExce ...

  9. [原创]Devexpress XtraReports 系列 7 创建Drill-Down(向下钻取)报表

    昨天发表了Devexpress XtraReports系列第六篇[原创]Devexpress XtraReports 系列 6 创建并排报表,今天我们继续. 今天的主题是创建Drill-Down报表. ...

随机推荐

  1. AssetBundle系列——资源的加载、简易的资源管理器

    每个需要进行资源管理的类都继承自IAssetManager,该类维护它所使用到的所有资源的一个资源列表.并且每个资源管理类可以重写其资源引用接口和解引用接口. 每个管理器有自己的管理策略,比如Scen ...

  2. 潮流设计:15个创意的 3D 字体版式作品欣赏

    3D字体设计是真的很棒,它最适用于广告.使用3D文字和不同的惊人效果,例如灯光或纹理带来了很多东西.在版式设计中,最重要的是消息.如果它抓住了用户的注意力,设计工作是在正确的轨道上. 您可能感兴趣的相 ...

  3. 基于HTML5实现的Heatmap热图3D应用

    Heatmap热图通过众多数据点信息,汇聚成直观可视化颜色效果,热图已广泛被应用于气象预报.医疗成像.机房温度监控等行业,甚至应用于竞技体育领域的数据分析. 已有众多文章分享了生成Heatmap热图原 ...

  4. mysqldump导出部分数据的方法: 加入--where参数

    mysqldump导出部分数据的方法: 加入--where参数 mysqldump -u用户名 -p密码 数据库名 表名 --where="筛选条件" > 导出文件路径 my ...

  5. struts2重点——ModelDriven

    一.属性驱动 在目标 Action 类中,通过 setXxx() 方法来接收请求参数. 二.模型驱动 1.ParametersInterceptor 拦截器工作原理 ParametersInterce ...

  6. Scrum团队成立3.0

    博客园 首页 新随笔 联系 订阅 管理 随笔 - 23  文章 - 0  评论 - 26 0428-Scrum团队成立3.0 ------------------------------3.0---- ...

  7. 0506团队项目-Scrum 项目1.0

    题目 1.应用NABCD模型,分析你们初步选定的项目,充分说明你们选题的理由. 2.录制为演说视频,上传到视频网站,并把链接发到团队博客上. 团队项目选题 金融工具:复利计算与投资记录项目继续升级,开 ...

  8. Node.js下基于Express + Socket.io 搭建一个基本的在线聊天室

    一.聊天室简单介绍 采用nodeJS设计,基于express框架,使用WebSocket编程之 socket.io机制.聊天室增加了 注册登录模块 ,并将用户个人信息和聊天记录存入数据库. 数据库采用 ...

  9. P6 EPPM R16.1安装与配置指南(二)

    P6 EPPM R16.1安装与配置指南(一) http://www.cnblogs.com/endv/p/5634620.html P6 EPPM R16.1安装与配置指南(二) 环境变量配置 新建 ...

  10. ajax post提交的方式

    ajax的post注意事项 注意post请求的Content-Type为application/x-www-form-urlencoded,参数是在请求体中,即上面请求中的Form Data(后台通过 ...