在項(xiàng)目中要進(jìn)行導(dǎo)出excel報(bào)表給客戶,里面有統(tǒng)計(jì),就心思用aspose.cells 配合實(shí)體類數(shù)據(jù)直接導(dǎo)出。結(jié)果呢比較麻煩。然后就檢索找到利用excel模板配合實(shí)體類數(shù)據(jù)導(dǎo)出。
總的來(lái)說(shuō)一般的報(bào)表生成,基本上是基于以下幾種方式:一種是基于微軟excel內(nèi)置的引擎來(lái)實(shí)現(xiàn);一種是構(gòu)造html格式的excle報(bào)表;一種是基于控件的方式來(lái)處理,基于控件有很多種方式,個(gè)人認(rèn)為比較有名的是aspose.cell和npoi,下面用到的是aspose.cell
效果圖:
excel模板及相關(guān)變量
報(bào)表1模板如下所示(其中通過(guò)引用集合的對(duì)象是通過(guò)&=來(lái)引用,對(duì)象的屬性或者列名,通過(guò)如&=export.作業(yè)完成計(jì)劃方式引用,非常直觀方便)
aspose.cell控件支持多種參數(shù)變量的綁定操作,如支持dataset、datatable、ilist集合,實(shí)體類集合、類對(duì)象等。
下面我主要用list 實(shí)體類集合
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]); //創(chuàng)建一個(gè)workbookdesigner對(duì)象 workbookdesigner designer = new workbookdesigner(); //制定報(bào)表模板 switch (strparm[4]) { case "工廠入貨箱單信息" : designer.open(server.mappath( @"model\allwarehousing.xls" )); break ; case "上貨開(kāi)箱信息" : 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 ; } //設(shè)置實(shí)體類對(duì)象<span style="color:#ff0000;">這里設(shè)置了export 變量,然后在模板里面我們就用了。 designer.setdatasource( "export" , getjianpinorzhendata); //報(bào)表標(biāo)題頭部 //可以擴(kuò)展多個(gè) designer.setdatasource( "exportutils" ,strparm[4]); //報(bào)表截止日期 designer.setdatasource( "exportdate" , datetime.now.tostring( "yyyy年mm月dd日" )); //根據(jù)數(shù)據(jù)源處理生成報(bào)表內(nèi)容 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 讀取數(shù)據(jù)
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>); //設(shè)置datatable對(duì)象 designer.setdatasource( "export" ,dt); //設(shè)置dataset對(duì)象 designer.setdatasource(ds.tables[ "export" ]); designer.process(); |
更多信息訪問(wèn)官方網(wǎng)站
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://blog.csdn.net/kongwei521/article/details/41647747