C#如何操作Excel數(shù)據(jù)透視表
一、概述
數(shù)據(jù)透視表(Pivot Table)是一種交互式的表,可以進(jìn)行某些計(jì)算,如求和與計(jì)數(shù)等,可動(dòng)態(tài)地改變透視表版面布置,也可以重新安排行號(hào)、列標(biāo)和頁(yè)字段。當(dāng)改變版面布置時(shí),數(shù)據(jù)透視表也會(huì)按照新的布置來(lái)進(jìn)行更新,可以說(shuō)是一個(gè)功能強(qiáng)大的數(shù)據(jù)分析工具。因此,本篇文章將介紹在C# 中關(guān)于Excel數(shù)據(jù)透視表的操作示例,示例內(nèi)容主要包含以下要點(diǎn):
1. 創(chuàng)建透視表
(1)創(chuàng)建數(shù)據(jù)緩存
(2)創(chuàng)建數(shù)據(jù)透視表
(3)添加行字段和列字段
(4)添加值字段
(5)設(shè)置樣式
2. 設(shè)置行折疊、展開(kāi)
3. 設(shè)置字段升序、降序
4. 刪除透視表
二、準(zhǔn)備工具
Spire.XLS for .NET (可支持80余種Excel內(nèi)置的數(shù)據(jù)透視表樣式)
PS:安裝后,注意在項(xiàng)目中引用Spire.XLS.dll再進(jìn)行代碼操作,dll文件在安裝路徑下的Bin文件夾中獲取。
三、示例操作
1.創(chuàng)建透視表
//創(chuàng)建一個(gè)Workbook類實(shí)例,并加載Excel文檔 Workbook workbook = new Workbook(); workbook.LoadFromFile("test.xlsx"); //獲取第一個(gè)工作表 Worksheet sheet = workbook.Worksheets[0]; //為需要匯總和分析的數(shù)據(jù)創(chuàng)建緩存 CellRange dataRange = sheet.Range["A1:D10"]; PivotCache cache = workbook.PivotCaches.Add(dataRange); //使用緩存創(chuàng)建數(shù)據(jù)透視表,并指定透視表的名稱以及在工作表中的位置 PivotTable pivotTable = sheet.PivotTables.Add("PivotTable", sheet.Range["A12"], cache); //添加行字段 var r1 = pivotTable.PivotFields["月份"]; r1.Axis = AxisTypes.Row; var r2 = pivotTable.PivotFields["廠商"]; r2.Axis = AxisTypes.Row; //設(shè)置行字段的標(biāo)題 pivotTable.Options.RowHeaderCaption = "月份"; //添加列字段 var col1 = pivotTable.PivotFields["產(chǎn)品"]; col1.Axis = AxisTypes.Column; //設(shè)置列字段的標(biāo)題 pivotTable.Options.ColumnHeaderCaption = "產(chǎn)品"; //添加值字段 pivotTable.DataFields.Add(pivotTable.PivotFields["總產(chǎn)量"], "求和項(xiàng):總產(chǎn)量", SubtotalTypes.Sum); //設(shè)置透視表的樣式(Spire.XLS共支持80余種Excel內(nèi)置的數(shù)據(jù)透視表樣式) pivotTable.BuiltInStyle = PivotBuiltInStyles.PivotStyleDark13; //保存并打開(kāi)文檔 workbook.SaveToFile("數(shù)據(jù)透視表.xlsx", ExcelVersion.Version2013); System.Diagnostics.Process.Start("數(shù)據(jù)透視表.xlsx");
測(cè)試結(jié)果:
2. 設(shè)置行折疊、展開(kāi)
//創(chuàng)建Workbook類對(duì)象,加載Excel文檔 Workbook workbook = new Workbook(); workbook.LoadFromFile("數(shù)據(jù)透視表.xlsx"); //獲取數(shù)據(jù)透視表 XlsPivotTable pivotTable = workbook.Worksheets[0].PivotTables[0] as XlsPivotTable; //計(jì)算數(shù)據(jù) pivotTable.CalculateData(); //展開(kāi)”月份”字段下“2”的詳細(xì)信息 (pivotTable.PivotFields["月份"] as Spire.Xls.Core.Spreadsheet.PivotTables.XlsPivotField).HideItemDetail("2", false); //折疊”月份”字段下“3”的詳細(xì)信息 (pivotTable.PivotFields["月份"] as Spire.Xls.Core.Spreadsheet.PivotTables.XlsPivotField).HideItemDetail("3", true); //保存并打開(kāi)文檔 workbook.SaveToFile("折疊、展開(kāi)行.xlsx", ExcelVersion.Version2013); System.Diagnostics.Process.Start("折疊、展開(kāi)行.xlsx");
測(cè)試結(jié)果:
3. 設(shè)置字段排序
這里支持三種不同類型的排序,可根據(jù)需要選擇相應(yīng)的排序類型。
//創(chuàng)建一個(gè)Workbook類對(duì)象,并加載Excel文檔 Workbook workbook = new Workbook(); workbook.LoadFromFile("數(shù)據(jù)透視表.xlsx"); //獲取數(shù)據(jù)透視表 Spire.Xls.Core.Spreadsheet.PivotTables.XlsPivotTable pivotTable = workbook.Worksheets[0].PivotTables[0] as Spire.Xls.Core.Spreadsheet.PivotTables.XlsPivotTable; //對(duì)指定字段進(jìn)行升序排序 pivotTable.PivotFields[2].SortType = PivotFieldSortType.Ascending; //保存并打開(kāi)文檔 workbook.SaveToFile("升序.xlsx", ExcelVersion.Version2013); System.Diagnostics.Process.Start("升序.xlsx");
測(cè)試結(jié)果:
4. 刪除透視表
刪除透視表可通過(guò)以下兩種方法:
- 根據(jù)透視表名稱刪除
- 根據(jù)透視表索引刪除
//創(chuàng)建一個(gè)工作簿,并加載Excel文檔 Workbook workbook = new Workbook(); workbook.LoadFromFile("數(shù)據(jù)透視表.xlsx"); //刪除第一張工作表上名稱為“PivotTable”的數(shù)據(jù)透視表 workbook.Worksheets[0].PivotTables.Remove("PivotTable"); //刪除第一張工作表上索引為0即第一個(gè)數(shù)據(jù)透視表 //workbook.Worksheets[0].PivotTables.RemoveAt(0); //保存文檔 workbook.SaveToFile("刪除數(shù)據(jù)透視表.xlsx", ExcelVersion.Version2013);
測(cè)試結(jié)果:
以上內(nèi)容為本次關(guān)于“Excel數(shù)據(jù)透視表的示例操作”的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:C#使用dynamic類型訪問(wèn)JObject對(duì)象
欄 目:C#教程
本文標(biāo)題:C#如何操作Excel數(shù)據(jù)透視表
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5205.html
您可能感興趣的文章
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已安裝軟件變化的方法
- 01-10C#實(shí)現(xiàn)判斷當(dāng)前操作用戶管理角色的方法
- 01-10Extjs4如何處理后臺(tái)json數(shù)據(jù)中日期和時(shí)間
- 01-10C#中DataGridView常用操作實(shí)例小結(jié)
- 01-10C#操作ftp類完整實(shí)例
- 01-10asp.net中XML如何做增刪改查操作
- 01-10C#路徑,文件,目錄及IO常見(jiàn)操作匯總
- 01-10C#操作IIS方法集合
- 01-10C#操作數(shù)據(jù)庫(kù)中存取圖片文件的方法
- 01-10C#操作 JSON方法匯總


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開(kāi)的解決方案
- 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#通過(guò)重寫(xiě)Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載