服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - 利用Aspose.Cells和Excel模板导出统计数据

利用Aspose.Cells和Excel模板导出统计数据

2022-03-06 13:45蝶恋花雨 C#

这篇文章主要为大家详细介绍了利用Aspose.Cells和Excel模板导出复杂的统计数据,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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

效果图:

利用Aspose.Cells和Excel模板导出统计数据

excel模板及相关变量

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

利用Aspose.Cells和Excel模板导出统计数据

利用Aspose.Cells和Excel模板导出统计数据

aspose.cell控件支持多种参数变量的绑定操作,如支持dataset、datatable、ilist集合,实体类集合、类对象等。

利用Aspose.Cells和Excel模板导出统计数据

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
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 读取数据

?
1
2
3
4
5
6
7
8
9
10
11
12
13
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

延伸 · 阅读

精彩推荐
  • C#C# 实现对PPT文档加密、解密及重置密码的操作方法

    C# 实现对PPT文档加密、解密及重置密码的操作方法

    这篇文章主要介绍了C# 实现对PPT文档加密、解密及重置密码的操作方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下...

    E-iceblue5012022-02-12
  • C#C#实现XML文件读取

    C#实现XML文件读取

    这篇文章主要为大家详细介绍了C#实现XML文件读取的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    Just_for_Myself6702022-02-22
  • C#C#设计模式之Visitor访问者模式解决长隆欢乐世界问题实例

    C#设计模式之Visitor访问者模式解决长隆欢乐世界问题实例

    这篇文章主要介绍了C#设计模式之Visitor访问者模式解决长隆欢乐世界问题,简单描述了访问者模式的定义并结合具体实例形式分析了C#使用访问者模式解决长...

    GhostRider9502022-01-21
  • C#WPF 自定义雷达图开发实例教程

    WPF 自定义雷达图开发实例教程

    这篇文章主要介绍了WPF 自定义雷达图开发实例教程,本文介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下...

    WinterFish13112021-12-06
  • C#深入解析C#中的交错数组与隐式类型的数组

    深入解析C#中的交错数组与隐式类型的数组

    这篇文章主要介绍了深入解析C#中的交错数组与隐式类型的数组,隐式类型的数组通常与匿名类型以及对象初始值设定项和集合初始值设定项一起使用,需要的...

    C#教程网6172021-11-09
  • C#C#通过KD树进行距离最近点的查找

    C#通过KD树进行距离最近点的查找

    这篇文章主要为大家详细介绍了C#通过KD树进行距离最近点的查找,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    帆帆帆6112022-01-22
  • C#Unity3D实现虚拟按钮控制人物移动效果

    Unity3D实现虚拟按钮控制人物移动效果

    这篇文章主要为大家详细介绍了Unity3D实现虚拟按钮控制人物移动效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一...

    shenqingyu060520232410972022-03-11
  • C#C#裁剪,缩放,清晰度,水印处理操作示例

    C#裁剪,缩放,清晰度,水印处理操作示例

    这篇文章主要为大家详细介绍了C#裁剪,缩放,清晰度,水印处理操作示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    吴 剑8332021-12-08