利用Aspose.Cells和Excel模板導(dǎo)出統(tǒng)計(jì)數(shù)據(jù)
在項(xiàng)目中要進(jìn)行導(dǎo)出Excel報(bào)表給客戶,里面有統(tǒng)計(jì),就心思用Aspose.Cells 配合實(shí)體類(lèi)數(shù)據(jù)直接導(dǎo)出。結(jié)果呢比較麻煩。然后就檢索找到利用Excel模板配合實(shí)體類(lèi)數(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í)體類(lèi)集合、類(lèi)對(duì)象等。
下面我主要用List 實(shí)體類(lèi)集合
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í)體類(lèi)對(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ù)
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í)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
c# HttpWebRequest通過(guò)代理服務(wù)器抓取網(wǎng)頁(yè)內(nèi)容應(yīng)用介紹
在C#項(xiàng)目開(kāi)發(fā)過(guò)程中可能會(huì)有些特殊的需求比如:用HttpWebRequest通過(guò)代理服務(wù)器驗(yàn)證后抓取網(wǎng)頁(yè)內(nèi)容,要想實(shí)現(xiàn)此方法并不容易,本文整理了一下,有需求的朋友可以參考下2012-11-11C#?Winform消息通知之系統(tǒng)本地通知local?toast?notification
這篇文章主要為大家介紹了C#?Winform消息通知之系統(tǒng)本地通知local?toast?notification使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08C#使用ToUpper()與ToLower()方法將字符串進(jìn)行大小寫(xiě)轉(zhuǎn)換的方法
這篇文章主要介紹了C#使用ToUpper()與ToLower()方法將字符串進(jìn)行大小寫(xiě)轉(zhuǎn)換的方法,實(shí)例分析了C#大小寫(xiě)轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下2015-04-04c# 對(duì)cookies(增、刪、改、查)的操作方法
以前覺(jué)得cookies操作無(wú)非就那么幾種,但是“杯具事件”還是很多的,下面分享一下對(duì)cookies的簡(jiǎn)單操作2013-04-04C#中Task.ContinueWith連續(xù)任務(wù)使用實(shí)例
本文主要介紹了C#中Task.ContinueWith連續(xù)任務(wù)使用實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02C# Winform下載文件并顯示進(jìn)度條的實(shí)現(xiàn)代碼
本來(lái)是要研究怎樣判斷下載完成,結(jié)果找到這個(gè)方法,可以在這個(gè)方法完成之后提示下載完成,需要的朋友可以參考下2014-07-07c#實(shí)現(xiàn)最簡(jiǎn)潔的快速排序(你絕對(duì)可以看懂)
這篇文章主要給大家介紹了關(guān)于利用c#實(shí)現(xiàn)如何最簡(jiǎn)潔的快速排序,實(shí)現(xiàn)的方法你絕對(duì)可以看懂,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用c#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05