当前位置: 首页 > news >正文

C# 如何在Excel 动态生成PivotTable

  Excel 中的透视表对于数据分析来说,非常的方便,而且很多业务人员对于Excel的操作也是非常熟悉的,因此用Excel作为分析数据的界面,不失为一种很好的选择。那么如何用C#从数据库中抓取数据,并在Excel 动态生成PivotTable呢?下面结合实例来说明。

一般来说,数据库的设计都遵循规范化的原则,从而减少数据的冗余,但是对于数据分析来说,数据冗余能够提高数据加载的速度,因此为了演示透视表,这里现在数据库中建立一个视图,将需要分析的数据整合到一个视图中。如下图所示:

  数据源准备好后,我们先来建立一个web应用程序,然后用NuGet加载Epplus程序包,如下图所示:

 在index.aspx前台页面中,编写如下脚本:

 1 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="index.aspx.cs" Inherits="ExcelPivot.Web.index" %>
 2 
 3 <!DOCTYPE html>
 4 <html xmlns="http://www.w3.org/1999/xhtml">
 5 <head runat="server">
 6 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
 7     <title>Excel PivotTable</title>
 8     <link rel="stylesheet" type="text/css" href="css/style.css" />  
 9 </head>
10 <body>
11     <form id="form1" runat="server">
12        <div id="container">
13 
14             <div id="contents">
15 
16                 <div id="post">
17                     <header>
18                         <h1> Excel PivotTable </h1>
19                     </header>
20                     <div id="metro-array" style="display: inline-block;">
21                         <div style="width: 230px; height: 230px; float: left; ">
22 
23                             <a class="metro-tile" style="cursor: pointer; width: 230px; height: 110px; display: block; background-color:#ff0000; color: #fff; margin-bottom: 10px;">
24                                 
25                                  <input type="button" runat="server" id="Button1" name="btn1" value="回款情况分析" onserverclick="btn1_ServerClick"  
26                                                    style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:230px; height:110px; cursor:pointer;"/>
27                             
28                             </a>
29 
30                             <a class="metro-tile" style="cursor: pointer; width: 230px; height: 110px; display: block; background-color:#ff6a00; color: #fff;">
31                                  <input type="button" runat="server" id="Button2" name="btn1" value="sampe1" onserverclick="btn1_ServerClick"  
32                                                    style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:230px; height:110px; cursor:pointer;"/>
33                             </a>
34                         </div>
35 
36                         <div style="width: 230px; height: 230px; float: left; margin-left: 10px">
37 
38                             <a class="metro-tile" style="cursor: pointer; width: 230px; height: 230px; display: block; background-color:#ffd800; color: #fff">
39                                  <input type="button" runat="server" id="btn1" name="btn1" value="sampe1" onserverclick="btn1_ServerClick"  
40                                                    style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:230px; height:230px; cursor:pointer;"/>
41                             </a>
42 
43                         </div>
44 
45                         <div style="width: 230px; height: 230px; float: left; margin-left: 10px">
46 
47                             <a class="metro-tile" style="cursor: pointer; width: 230px; height: 110px; display: block; background-color:#0094ff; color: #fff; margin-bottom: 10px;">
48                                  <input type="button" runat="server" id="Button3" name="btn1" value="sampe1" onserverclick="btn1_ServerClick"  
49                                                    style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:230px; height:110px; cursor:pointer;"/>
50                             </a>
51 
52                             <a class="metro-tile" style="cursor: pointer; width: 110px; height: 110px; margin-right: 10px; display: block; float: left; background-color: #4800ff; color: #fff;">
53                                  <input type="button" runat="server" id="Button4" name="btn1" value="sampe1" onserverclick="btn1_ServerClick"  
54                                                    style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:110px; height:110px; cursor:pointer;"/>
55                             </a>
56 
57                             <a class="metro-tile" style="cursor: pointer; width: 110px; height: 110px; display: block; background-color: #b200ff; float: right; color: #fff;">
58                                  <input type="button" runat="server" id="Button5" name="btn1" value="sampe1" onserverclick="btn1_ServerClick"  
59                                                    style="background-color:transparent; color:white; font-size:16px;float:left; border:0; width:110px; height:110px; cursor:pointer;"/>
60                             </a>
61                         </div>
62 
63                     </div>
64                 </div>
65 
66             </div>
67         </div>
68     </form>
69 </body>
70     <script src="js/tileJs.js" type="text/javascript"></script>
71 </html>

其中 TileJs是一个开源的构建类似win8 Metro风格的javascript库。

编写后台脚本:

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Linq;
  4 using System.Web;
  5 using System.Web.UI;
  6 using System.Web.UI.WebControls;
  7 using OfficeOpenXml;
  8 using OfficeOpenXml.Table;
  9 using OfficeOpenXml.ConditionalFormatting;
 10 using OfficeOpenXml.Style;
 11 using OfficeOpenXml.Utils;
 12 using OfficeOpenXml.Table.PivotTable;
 13 using System.IO;
 14 using System.Data.SqlClient;
 15 using System.Data;
 16 namespace ExcelPivot.Web
 17 {
 18     public partial class index : System.Web.UI.Page
 19     {
 20         protected void Page_Load(object sender, EventArgs e)
 21         {
 22 
 23         }
 24         private DataTable getDataSource()
 25         {
 26             //createDataTable();
 27             //return ProductInfo;
 28 
 29             SqlConnection conn = new SqlConnection();
 30             conn.ConnectionString = "Data Source=.;Initial Catalog=olap;Persist Security Info=True;User ID=sa;Password=sa";
 31             conn.Open();
 32 
 33             SqlDataAdapter ada = new SqlDataAdapter("select * from v_pm_olap_test", conn);
 34             DataSet ds = new DataSet();
 35             ada.Fill(ds);
 36 
 37             return ds.Tables[0];
 38 
 39 
 40 
 41         }
 42       
 43         protected void btn1_ServerClick(object sender, EventArgs e)
 44         {
 45             try
 46             {
 47                 DataTable table = getDataSource();
 48                 string path = "_demo_" + System.Guid.NewGuid().ToString().Replace("-", "_") + ".xls";
 49                 //string path = "_demo.xls";
 50                 FileInfo fileInfo = new FileInfo(path);
 51                 var excel = new ExcelPackage(fileInfo);
 52 
 53                 var wsPivot = excel.Workbook.Worksheets.Add("Pivot");
 54                 var wsData = excel.Workbook.Worksheets.Add("Data");
 55                 wsData.Cells["A1"].LoadFromDataTable(table, true, OfficeOpenXml.Table.TableStyles.Medium6);
 56                 if (table.Rows.Count != 0)
 57                 {
 58                     foreach (DataColumn col in table.Columns)
 59                     {
 60                      
 61                         if (col.DataType == typeof(System.DateTime))
 62                         {
 63                             var colNumber = col.Ordinal + 1;
 64                             var range = wsData.Cells[2, colNumber, table.Rows.Count + 1, colNumber];
 65                             range.Style.Numberformat.Format = "yyyy-MM-dd";
 66                         }
 67                         else
 68                         {
 69 
 70                         }
 71                     }
 72                 }
 73 
 74                 var dataRange = wsData.Cells[wsData.Dimension.Address.ToString()];
 75                 dataRange.AutoFitColumns();
 76                 var pivotTable = wsPivot.PivotTables.Add(wsPivot.Cells["A1"], dataRange, "Pivot");
 77                 pivotTable.MultipleFieldFilters = true;
 78                 pivotTable.RowGrandTotals = true;
 79                 pivotTable.ColumGrandTotals = true;
 80                 pivotTable.Compact = true;
 81                 pivotTable.CompactData = true;
 82                 pivotTable.GridDropZones = false;
 83                 pivotTable.Outline = false;
 84                 pivotTable.OutlineData = false;
 85                 pivotTable.ShowError = true;
 86                 pivotTable.ErrorCaption = "[error]";
 87                 pivotTable.ShowHeaders = true;
 88                 pivotTable.UseAutoFormatting = true;
 89                 pivotTable.ApplyWidthHeightFormats = true;
 90                 pivotTable.ShowDrill = true;
 91                 pivotTable.FirstDataCol = 3;
 92                 //pivotTable.RowHeaderCaption = "行";
 93 
 94                 //row field
 95                 var field004 = pivotTable.Fields["销售客户经理"];
 96                 pivotTable.RowFields.Add(field004);
 97 
 98                 var field001 = pivotTable.Fields["项目简称"];
 99                 pivotTable.RowFields.Add(field001);
100                 //field001.ShowAll = false;
101 
102                 //column field
103                 var field002 = pivotTable.Fields[""];
104                 pivotTable.ColumnFields.Add(field002);
105                 field002.Sort = OfficeOpenXml.Table.PivotTable.eSortType.Ascending;
106                 var field005 = pivotTable.Fields[""];
107                 pivotTable.ColumnFields.Add(field005);
108                 field005.Sort = OfficeOpenXml.Table.PivotTable.eSortType.Ascending;
109 
110                 //data field
111                 var field003 = pivotTable.Fields["回款金额"];
112                 field003.Sort = OfficeOpenXml.Table.PivotTable.eSortType.Descending;
113                 pivotTable.DataFields.Add(field003);
114 
115                 pivotTable.RowGrandTotals = false;
116                 pivotTable.ColumGrandTotals = false;
117               
118                 //save file
119                 excel.Save();
120                 //open excel file
121                 string file = @"C:\Windows\explorer.exe";
122                 System.Diagnostics.Process.Start(file, path);
123 
124             }
125             catch (Exception ex)
126             {
127               Response.Write(ex.Message);
128             }
129         }
130     }
131 }

  编译运行,如下图所示:

 单击 [回款情况分析],稍等片刻,会打开Excel,并自动生成透视表,如下图所示:

相关文章:

  • 08.Android之View事件问题
  • .naturalWidth 和naturalHeight属性,
  • 数据模型
  • 深度解析利用ES6进行Promise封装总结
  • 上传本地项目到git.oschina
  • ES6系统学习----从Apollo Client看解构赋值
  • 前端临床手札——文件上传
  • IDEA Git版本回滚提交方式
  • spring framework 模块简介
  • Vue2.5 零基础开发去哪儿网实战(二) - 起步 Vue.js
  • 数组(list)分组、分段
  • 编译并导入OpenSSL
  • Rsync软件错误总结
  • 《TCP/IP具体解释卷2:实现》笔记--ICMP:Internet控制报文协议
  • 小程序button引导用户授权
  • [笔记] php常见简单功能及函数
  • 【从零开始安装kubernetes-1.7.3】2.flannel、docker以及Harbor的配置以及作用
  • Docker: 容器互访的三种方式
  • iBatis和MyBatis在使用ResultMap对应关系时的区别
  • java取消线程实例
  • js
  • Node项目之评分系统(二)- 数据库设计
  • Redis在Web项目中的应用与实践
  • socket.io+express实现聊天室的思考(三)
  • 阿里云Kubernetes容器服务上体验Knative
  • 创建一个Struts2项目maven 方式
  • 基于 Ueditor 的现代化编辑器 Neditor 1.5.4 发布
  • 跨域
  • 普通函数和构造函数的区别
  • 删除表内多余的重复数据
  • 手写双向链表LinkedList的几个常用功能
  • 项目管理碎碎念系列之一:干系人管理
  • 一个SAP顾问在美国的这些年
  • 原生js练习题---第五课
  • 中国人寿如何基于容器搭建金融PaaS云平台
  • Redis4.x新特性 -- 萌萌的MEMORY DOCTOR
  • ​【已解决】npm install​卡主不动的情况
  • $emit传递多个参数_PPC和MIPS指令集下二进制代码中函数参数个数的识别方法
  • (C#)Windows Shell 外壳编程系列9 - QueryInfo 扩展提示
  • (Java)【深基9.例1】选举学生会
  • (Java实习生)每日10道面试题打卡——JavaWeb篇
  • (备忘)Java Map 遍历
  • (博弈 sg入门)kiki's game -- hdu -- 2147
  • (二十一)devops持续集成开发——使用jenkins的Docker Pipeline插件完成docker项目的pipeline流水线发布
  • (附源码)spring boot北京冬奥会志愿者报名系统 毕业设计 150947
  • (力扣)1314.矩阵区域和
  • (入门自用)--C++--抽象类--多态原理--虚表--1020
  • (算法)求1到1亿间的质数或素数
  • (一)Neo4j下载安装以及初次使用
  • (转)ObjectiveC 深浅拷贝学习
  • (转)winform之ListView
  • (转)从零实现3D图像引擎:(8)参数化直线与3D平面函数库
  • (转)母版页和相对路径
  • (轉)JSON.stringify 语法实例讲解
  • .net 4.0 A potentially dangerous Request.Form value was detected from the client 的解决方案