aspose.cells 导出 html中的表格,利用Aspose.Cells和Excel模板导出复杂的统计数据

在项目中要进行导出Excel报表给客户,里面有统计,就心思用Aspose.Cells 配合实体类数据直接导出。结果呢比较麻烦。然后就检索找到利用Excel模板配合实体类数据导出。

总的来说一般的报表生成,基本上是基于以下几种方式:一种是基于微软Excel内置的引擎来实现;一种是构造HTML格式的Excle报表;一种是基于控件的方式来处理,基于控件有很多种方式,个人认为比较有名的是Aspose.Cell和NPOI,下面用到的是Aspose.Cell

效果图:

c0bc0d38cef0dea06e7ab83c6efcb50e.png

Excel模板及相关变量

报表1模板如下所示(其中通过引用集合的对象是通过&=来引用,对象的属性或者列名,通过如&=Export.作业完成计划方式引用,非常直观方便)

0a958c7ec5488a98a55f69ca381eb288.png

d1e9b49411850a883ab0f36230e84982.png

Aspose.Cell控件支持多种参数变量的绑定操作,如支持DataSet、Datatable、IList集合,实体类集合、类对象等。

f4c048c587629103594038a90cf01083.png

下面我主要用List 实体类集合

protected void ExportExcel_ServerClick(object sender, EventArgs e)

{

HttpCookie getCookies = Request.Cookies["UserLogin"];

if (getCookies != null)

{

string[] strParm = hfExcelData.Value.Split(',');

List 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;

}

//设置实体类对象这里设置了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);

//设置DataTable对象

designer.SetDataSource("Export",dt);

//设置DataSet对象

designer.SetDataSource(ds.Tables["Export"]);

designer.Process();

更多信息访问官方网站

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值