C#實(shí)現(xiàn)Excel動(dòng)態(tài)生成PivotTable
Excel 中的透視表對(duì)于數(shù)據(jù)分析來(lái)說,非常的方便,而且很多業(yè)務(wù)人員對(duì)于Excel的操作也是非常熟悉的,因此用Excel作為分析數(shù)據(jù)的界面,不失為一種很好的選擇。那么如何用C#從數(shù)據(jù)庫(kù)中抓取數(shù)據(jù),并在Excel 動(dòng)態(tài)生成PivotTable呢?下面結(jié)合實(shí)例來(lái)說明。
一般來(lái)說,數(shù)據(jù)庫(kù)的設(shè)計(jì)都遵循規(guī)范化的原則,從而減少數(shù)據(jù)的冗余,但是對(duì)于數(shù)據(jù)分析來(lái)說,數(shù)據(jù)冗余能夠提高數(shù)據(jù)加載的速度,因此為了演示透視表,這里現(xiàn)在數(shù)據(jù)庫(kù)中建立一個(gè)視圖,將需要分析的數(shù)據(jù)整合到一個(gè)視圖中。如下圖所示:
數(shù)據(jù)源準(zhǔn)備好后,我們先來(lái)建立一個(gè)web應(yīng)用程序,然后用NuGet加載Epplus程序包,如下圖所示:
在index.aspx前臺(tái)頁(yè)面中,編寫如下腳本:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="index.aspx.cs" Inherits="ExcelPivot.Web.index" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>Excel PivotTable</title> <link rel="stylesheet" type="text/css" href="css/style.css" /> </head> <body> <form id="form1" runat="server"> <div id="container"> <div id="contents"> <div id="post"> <header> <h1> Excel PivotTable </h1> </header> <div id="metro-array" style="display: inline-block;"> <div style="width: 230px; height: 230px; float: left; "> <a class="metro-tile" style="cursor: pointer; width: 230px; height: 110px; display: block; background-color:#ff0000; color: #fff; margin-bottom: 10px;"> <input type="button" runat="server" id="Button1" name="btn1" value="回款情況分析" onserverclick="btn1_ServerClick" style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:230px; height:110px; cursor:pointer;"/> </a> <a class="metro-tile" style="cursor: pointer; width: 230px; height: 110px; display: block; background-color:#ff6a00; color: #fff;"> <input type="button" runat="server" id="Button2" name="btn1" value="sampe1" onserverclick="btn1_ServerClick" style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:230px; height:110px; cursor:pointer;"/> </a> </div> <div style="width: 230px; height: 230px; float: left; margin-left: 10px"> <a class="metro-tile" style="cursor: pointer; width: 230px; height: 230px; display: block; background-color:#ffd800; color: #fff"> <input type="button" runat="server" id="btn1" name="btn1" value="sampe1" onserverclick="btn1_ServerClick" style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:230px; height:230px; cursor:pointer;"/> </a> </div> <div style="width: 230px; height: 230px; float: left; margin-left: 10px"> <a class="metro-tile" style="cursor: pointer; width: 230px; height: 110px; display: block; background-color:#0094ff; color: #fff; margin-bottom: 10px;"> <input type="button" runat="server" id="Button3" name="btn1" value="sampe1" onserverclick="btn1_ServerClick" style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:230px; height:110px; cursor:pointer;"/> </a> <a class="metro-tile" style="cursor: pointer; width: 110px; height: 110px; margin-right: 10px; display: block; float: left; background-color: #4800ff; color: #fff;"> <input type="button" runat="server" id="Button4" name="btn1" value="sampe1" onserverclick="btn1_ServerClick" style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:110px; height:110px; cursor:pointer;"/> </a> <a class="metro-tile" style="cursor: pointer; width: 110px; height: 110px; display: block; background-color: #b200ff; float: right; color: #fff;"> <input type="button" runat="server" id="Button5" name="btn1" value="sampe1" onserverclick="btn1_ServerClick" style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:110px; height:110px; cursor:pointer;"/> </a> </div> </div> </div> </div> </div> </form> </body> <script src="js/tileJs.js" type="text/javascript"></script> </html>
其中 TileJs是一個(gè)開源的構(gòu)建類似win8 Metro風(fēng)格的javascript庫(kù)。
編寫后臺(tái)腳本:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using OfficeOpenXml; using OfficeOpenXml.Table; using OfficeOpenXml.ConditionalFormatting; using OfficeOpenXml.Style; using OfficeOpenXml.Utils; using OfficeOpenXml.Table.PivotTable; using System.IO; using System.Data.SqlClient; using System.Data; namespace ExcelPivot.Web { public partial class index : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { } private DataTable getDataSource() { //createDataTable(); //return ProductInfo; SqlConnection conn = new SqlConnection(); conn.ConnectionString = "Data Source=.;Initial Catalog=olap;Persist Security Info=True;User ID=sa;Password=sa"; conn.Open(); SqlDataAdapter ada = new SqlDataAdapter("select * from v_pm_olap_test", conn); DataSet ds = new DataSet(); ada.Fill(ds); return ds.Tables[0]; } protected void btn1_ServerClick(object sender, EventArgs e) { try { DataTable table = getDataSource(); string path = "_demo_" + System.Guid.NewGuid().ToString().Replace("-", "_") + ".xls"; //string path = "_demo.xls"; FileInfo fileInfo = new FileInfo(path); var excel = new ExcelPackage(fileInfo); var wsPivot = excel.Workbook.Worksheets.Add("Pivot"); var wsData = excel.Workbook.Worksheets.Add("Data"); wsData.Cells["A1"].LoadFromDataTable(table, true, OfficeOpenXml.Table.TableStyles.Medium6); if (table.Rows.Count != 0) { foreach (DataColumn col in table.Columns) { if (col.DataType == typeof(System.DateTime)) { var colNumber = col.Ordinal + 1; var range = wsData.Cells[2, colNumber, table.Rows.Count + 1, colNumber]; range.Style.Numberformat.Format = "yyyy-MM-dd"; } else { } } } var dataRange = wsData.Cells[wsData.Dimension.Address.ToString()]; dataRange.AutoFitColumns(); var pivotTable = wsPivot.PivotTables.Add(wsPivot.Cells["A1"], dataRange, "Pivot"); pivotTable.MultipleFieldFilters = true; pivotTable.RowGrandTotals = true; pivotTable.ColumGrandTotals = true; pivotTable.Compact = true; pivotTable.CompactData = true; pivotTable.GridDropZones = false; pivotTable.Outline = false; pivotTable.OutlineData = false; pivotTable.ShowError = true; pivotTable.ErrorCaption = "[error]"; pivotTable.ShowHeaders = true; pivotTable.UseAutoFormatting = true; pivotTable.ApplyWidthHeightFormats = true; pivotTable.ShowDrill = true; pivotTable.FirstDataCol = 3; //pivotTable.RowHeaderCaption = "行"; //row field var field004 = pivotTable.Fields["銷售客戶經(jīng)理"]; pivotTable.RowFields.Add(field004); var field001 = pivotTable.Fields["項(xiàng)目簡(jiǎn)稱"]; pivotTable.RowFields.Add(field001); //field001.ShowAll = false; //column field var field002 = pivotTable.Fields["年"]; pivotTable.ColumnFields.Add(field002); field002.Sort = OfficeOpenXml.Table.PivotTable.eSortType.Ascending; var field005 = pivotTable.Fields["月"]; pivotTable.ColumnFields.Add(field005); field005.Sort = OfficeOpenXml.Table.PivotTable.eSortType.Ascending; //data field var field003 = pivotTable.Fields["回款金額"]; field003.Sort = OfficeOpenXml.Table.PivotTable.eSortType.Descending; pivotTable.DataFields.Add(field003); pivotTable.RowGrandTotals = false; pivotTable.ColumGrandTotals = false; //save file excel.Save(); //open excel file string file = @"C:\Windows\explorer.exe"; System.Diagnostics.Process.Start(file, path); } catch (Exception ex) { Response.Write(ex.Message); } } } }
編譯運(yùn)行,如下圖所示:
單擊 [回款情況分析],稍等片刻,會(huì)打開Excel,并自動(dòng)生成透視表,如下圖所示:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助
相關(guān)文章
Unity shader實(shí)現(xiàn)頂點(diǎn)動(dòng)畫波動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了Unity shader實(shí)現(xiàn)頂點(diǎn)動(dòng)畫波動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04C#中判斷、驗(yàn)證字符串是否為日期格式的實(shí)現(xiàn)代碼
這篇文章主要介紹了C#中判斷、驗(yàn)證字符串是否為日期格式的實(shí)現(xiàn)代碼,使用DateTime類中自帶的兩個(gè)方法實(shí)現(xiàn),需要的朋友可以參考下2014-08-08C#制作網(wǎng)站掛機(jī)程序的實(shí)現(xiàn)示例
本文主要介紹了C#制作網(wǎng)站掛機(jī)程序,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10