利用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í)體類數(shù)據(jù)直接導(dǎo)出。結(jié)果呢比較麻煩。然后就檢索找到利用Excel模板配合實(shí)體類數(shù)據(jù)導(dǎo)出。
總的來說一般的報(bào)表生成,基本上是基于以下幾種方式:一種是基于微軟Excel內(nèi)置的引擎來實(shí)現(xiàn);一種是構(gòu)造HTML格式的Excle報(bào)表;一種是基于控件的方式來處理,基于控件有很多種方式,個(gè)人認(rèn)為比較有名的是Aspose.Cell和NPOI,下面用到的是Aspose.Cell
效果圖:
Excel模板及相關(guān)變量
報(bào)表1模板如下所示(其中通過引用集合的對象是通過&=來引用,對象的屬性或者列名,通過如&=Export.作業(yè)完成計(jì)劃方式引用,非常直觀方便)
Aspose.Cell控件支持多種參數(shù)變量的綁定操作,如支持DataSet、Datatable、IList集合,實(shí)體類集合、類對象等。
下面我主要用List 實(shí)體類集合
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對象 WorkbookDesigner designer = new WorkbookDesigner(); //制定報(bào)表模板 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; } //設(shè)置實(shí)體類對象<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對象 designer.SetDataSource("Export",dt); //設(shè)置DataSet對象 designer.SetDataSource(ds.Tables["Export"]); designer.Process();
更多信息訪問官方網(wǎng)站
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:c#打開py文件的方法
欄 目:C#教程
下一篇:C# Winform實(shí)現(xiàn)導(dǎo)入和導(dǎo)出Excel文件
本文標(biāo)題:利用Aspose.Cells和Excel模板導(dǎo)出統(tǒng)計(jì)數(shù)據(jù)
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/4979.html
您可能感興趣的文章
- 01-10Extjs4如何處理后臺(tái)json數(shù)據(jù)中日期和時(shí)間
- 01-10C#利用反射技術(shù)實(shí)現(xiàn)去掉按鈕選中時(shí)的邊框效果
- 01-10C#及WPF獲取本機(jī)所有字體和顏色的方法
- 01-10同步調(diào)用和異步調(diào)用WebService
- 01-10C#編程自學(xué)之?dāng)?shù)據(jù)類型和變量二
- 01-10C#編程自學(xué)之?dāng)?shù)據(jù)類型和變量三
- 01-10C#編程自學(xué)之運(yùn)算符和表達(dá)式
- 01-10C#裝箱和拆箱原理詳解
- 01-10C#編程自學(xué)之類和對象
- 01-10C#圖片處理3種高級應(yīng)用


閱讀排行
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 08-05織夢dedecms什么時(shí)候用欄目交叉功能?
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery