好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

利用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();

更多信息访问 官方网站

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/kongwei521/article/details/41647747

dy("nrwz");

查看更多关于利用Aspose.Cells和Excel模板导出统计数据的详细内容...

  阅读:46次