利用Aspose.Cells和Excel模板導出統(tǒng)計數(shù)據(jù)
在項目中要進行導出Excel報表給客戶,里面有統(tǒng)計,就心思用Aspose.Cells 配合實體類數(shù)據(jù)直接導出。結(jié)果呢比較麻煩。然后就檢索找到利用Excel模板配合實體類數(shù)據(jù)導出。
總的來說一般的報表生成,基本上是基于以下幾種方式:一種是基于微軟Excel內(nèi)置的引擎來實現(xiàn);一種是構(gòu)造HTML格式的Excle報表;一種是基于控件的方式來處理,基于控件有很多種方式,個人認為比較有名的是Aspose.Cell和NPOI,下面用到的是Aspose.Cell
效果圖:
Excel模板及相關(guān)變量
報表1模板如下所示(其中通過引用集合的對象是通過&=來引用,對象的屬性或者列名,通過如&=Export.作業(yè)完成計劃方式引用,非常直觀方便)
Aspose.Cell控件支持多種參數(shù)變量的綁定操作,如支持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]); //創(chuàng)建一個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日")); //根據(jù)數(shù)據(jù)源處理生成報表內(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>); //設置DataTable對象 designer.SetDataSource("Export",dt); //設置DataSet對象 designer.SetDataSource(ds.Tables["Export"]); designer.Process();
更多信息訪問官方網(wǎng)站
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
c# HttpWebRequest通過代理服務器抓取網(wǎng)頁內(nèi)容應用介紹
在C#項目開發(fā)過程中可能會有些特殊的需求比如:用HttpWebRequest通過代理服務器驗證后抓取網(wǎng)頁內(nèi)容,要想實現(xiàn)此方法并不容易,本文整理了一下,有需求的朋友可以參考下2012-11-11C#?Winform消息通知之系統(tǒng)本地通知local?toast?notification
這篇文章主要為大家介紹了C#?Winform消息通知之系統(tǒng)本地通知local?toast?notification使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08C#使用ToUpper()與ToLower()方法將字符串進行大小寫轉(zhuǎn)換的方法
這篇文章主要介紹了C#使用ToUpper()與ToLower()方法將字符串進行大小寫轉(zhuǎn)換的方法,實例分析了C#大小寫轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下2015-04-04C#中Task.ContinueWith連續(xù)任務使用實例
本文主要介紹了C#中Task.ContinueWith連續(xù)任務使用實例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02C# Winform下載文件并顯示進度條的實現(xiàn)代碼
本來是要研究怎樣判斷下載完成,結(jié)果找到這個方法,可以在這個方法完成之后提示下載完成,需要的朋友可以參考下2014-07-07