利用Aspose.Cells和Excel模板导出统计数据
程序员文章站
2023-12-14 09:47:34
在项目中要进行导出excel报表给客户,里面有统计,就心思用aspose.cells 配合实体类数据直接导出。结果呢比较麻烦。然后就检索找到利用excel模板配合实体类数据...
在项目中要进行导出excel报表给客户,里面有统计,就心思用aspose.cells 配合实体类数据直接导出。结果呢比较麻烦。然后就检索找到利用excel模板配合实体类数据导出。
总的来说一般的报表生成,基本上是基于以下几种方式:一种是基于微软excel内置的引擎来实现;一种是构造html格式的excle报表;一种是基于控件的方式来处理,基于控件有很多种方式,个人认为比较有名的是aspose.cell和npoi,下面用到的是aspose.cell
效果图:
excel模板及相关变量
报表1模板如下所示(其中通过引用集合的对象是通过&=来引用,对象的属性或者列名,通过如&=export.作业完成计划方式引用,非常直观方便)
aspose.cell控件支持多种参数变量的绑定操作,如支持dataset、datatable、ilist集合,实体类集合、类对象等。
下面我主要用list 实体类集合
protected void exportexcel_serverclick(object sender, eventargs e) { httpcookie getcookies = request.cookies["userlogin"]; if (getcookies != null) { string[] strparm = hfexceldata.value.split(','); list<jianpinorzhen_view> getjianpinorzhendata = searchexportdata.lstsearchexportjianpinorzhen (server.urldecode(getcookies["sqlconstring"]), getcookies["customcode"],getcookies["customtype"], strparm[0], strparm[1], strparm[2], strparm[3], strparm[4]); //创建一个workbookdesigner对象 workbookdesigner designer = new workbookdesigner(); //制定报表模板 switch (strparm[4]) { case "工厂入货箱单信息": designer.open(server.mappath(@"model\allwarehousing.xls")); break; case "上货开箱信息": designer.open(server.mappath(@"model\warehousing.xls")); break; case "检品之后信息": designer.open(server.mappath(@"model\dress_jp.xls")); break; case "检针之后信息": designer.open(server.mappath(@"model\dress_jz.xls")); break; default: break; } //设置实体类对象<span style="color:#ff0000;">这里设置了export 变量,然后在模板里面我们就用了。 designer.setdatasource("export", getjianpinorzhendata); //报表标题头部 //可以扩展多个 designer.setdatasource("exportutils",strparm[4]); //报表截止日期 designer.setdatasource("exportdate", datetime.now.tostring("yyyy年mm月dd日")); //根据数据源处理生成报表内容 designer.process(); //客户端保存的文件名//如果保存的文件名是汉字的话一定要编码,否则就是乱码 httputility.urlencode(strparm[4]) string filename = httputility.urlencode(strparm[4]) + "_" + datetime.now.tostring("yyyymmddhhmmss") + ".xls"; designer.save(filename, savetype.openinexcel, fileformattype.excel2003, response); response.flush(); response.close(); designer = null; response.end(); }}
datatable 读取数据
datatable dt = excutedatatable(querysql); dt.tablename = "export"; if (dt.rows.count == 0) return; workbookdesigner designer = new workbookdesigner(); string filename = httputility.urlencode(strparm[4]) + "_" + datetime.now.tostring("yyyymmddhhmmss") + ".xls"; designer.open(filename<code class="csharp spaces"></code>); //设置datatable对象 designer.setdatasource("export",dt); //设置dataset对象 designer.setdatasource(ds.tables["export"]); designer.process();
更多信息访问官方网站
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。