C#教程

关注公众号 jb51net

关闭
首页 > 软件编程 > C#教程 > C# Excel创建数据透视表

C#使用Spire.XLS在Excel中创建数据透视表

作者:缺点内向

在C#环境下进行Excel自动化,有多种方案可供选择,例如Microsoft Office Interop、EPPlus等,但对于需要处理复杂Excel功能,尤其是数据透视表、图表等高级特性,Spire.XLS凭借其独特的优势脱颖而出,所以本文给大家介绍了如何使用Spire.XLS在Excel中创建数据透视表

引言

在 C# 环境下进行 Excel 自动化,有多种方案可供选择,例如 Microsoft Office Interop、EPPlus 等。但对于需要处理复杂 Excel 功能,尤其是数据透视表、图表等高级特性,并且注重性能和部署便利性的场景,Spire.XLS 凭借其独特的优势脱颖而出。

为什么选择 Spire.XLS 进行 Excel 自动化?

Spire.XLS 的核心特点与优势:

Spire.XLS 创建数据透视表核心步骤详解

1. 安装 Spire.XLS 库

首先,您需要在您的 C# 项目中安装 Spire.XLS。最简单的方式是通过 NuGet 包管理器:

  1. 打开 Visual Studio。
  2. 在“解决方案资源管理器”中,右键点击您的项目,选择“管理 NuGet 程序包”。
  3. 在“浏览”选项卡中搜索 Spire.XLS
  4. 点击“安装”。

2. 准备数据源

数据透视表需要一个结构化的数据源。通常,这意味着您的数据应该在一个连续的单元格区域中,并且第一行作为表头(字段名称)。

例如,我们准备如下销售数据:

销售员产品区域销售额订单日期
张三笔记本华东50002023/1/1
李四手机华南30002023/1/2
王五笔记本华北60002023/1/3
张三手机华东45002023/1/4
李四平板华南20002023/1/5
王五笔记本华中70002023/1/6

3. 代码示例 1: 初始化工作簿与添加数据

以下代码演示如何创建一个新的 Excel 工作簿,并填充上述销售数据作为数据透视表的源数据。

using Spire.Xls;
using Spire.Xls.PivotTable;
using System;

namespace SpireXlsPivotTableDemo
{
    class Program
    {
        static void Main(string[] args)
        {
            // 创建一个新的工作簿
            Workbook workbook = new Workbook();
            // 获取第一个工作表
            Worksheet sheet = workbook.Worksheets[0];
            sheet.Name = "原始数据";

            // 写入表头
            sheet.Range["A1"].Value = "销售员";
            sheet.Range["B1"].Value = "产品";
            sheet.Range["C1"].Value = "区域";
            sheet.Range["D1"].Value = "销售额";
            sheet.Range["E1"].Value = "订单日期";

            // 写入数据
            string[,] data = new string[,]
            {
                {"张三", "笔记本", "华东", "5000", "2023/1/1"},
                {"李四", "手机", "华南", "3000", "2023/1/2"},
                {"王五", "笔记本", "华北", "6000", "2023/1/3"},
                {"张三", "手机", "华东", "4500", "2023/1/4"},
                {"李四", "平板", "华南", "2000", "2023/1/5"},
                {"王五", "笔记本", "华中", "7000", "2023/1/6"},
                {"张三", "平板", "华北", "3500", "2023/1/7"},
                {"李四", "笔记本", "华东", "5500", "2023/1/8"},
                {"王五", "手机", "华南", "4000", "2023/1/9"},
            };

            for (int i = 0; i < data.GetLength(0); i++)
            {
                for (int j = 0; j < data.GetLength(1); j++)
                {
                    sheet.Range[i + 2, j + 1].Value = data[i, j];
                }
            }

            // 调整列宽以适应内容
            sheet.AutoFitColumn(1);
            sheet.AutoFitColumn(2);
            sheet.AutoFitColumn(3);
            sheet.AutoFitColumn(4);
            sheet.AutoFitColumn(5);

            Console.WriteLine("原始数据已准备完成。");

            // 后续将在这里添加创建数据透视表的代码
            // ...
        }
    }
}

4. 代码示例 2: 创建和配置数据透视表

接下来,我们将在同一个工作簿中创建一个新的工作表,并在其中创建并配置数据透视表。我们将以“销售员”作为行字段,“产品”作为列字段,并汇总“销售额”。

              // ... (接上一个代码示例)

            // 定义数据源范围
            CellRange dataRange = sheet.Range["A1:E10"]; // 包含表头和所有数据

            // 添加一个新的工作表用于放置数据透视表
            Worksheet pivotSheet = workbook.Worksheets.Add("销售数据透视表");
            
            // 创建一个数据透视缓存
            // PivotCache cache = workbook.PivotCaches.Add(dataRange); // 也可以直接使用数据范围创建
            
            // 添加数据透视表到新的工作表,指定其显示位置为 A1
            // 第一个参数是透视表的名称,第二个参数是透视表在目标工作表中的起始位置
            // 第三个参数是数据源范围
            PivotTable pt = pivotSheet.PivotTables.Add("销售分析透视表", pivotSheet.Range["A1"], dataRange);
            
            // 设置行字段
            // 将“销售员”字段添加到行区域
            PivotField rowField = pt.PivotFields["销售员"];
            rowField.Axis = AxisTypes.Row;
            // 启用重复项目标签,使得每个销售员的名称都显示
            rowField.RepeatItemLabels = true; 
            // 启用自动显示,如果数据量大,可以自动显示前N个或后N个
            rowField.IsAutoShow = true;

            // 设置列字段
            // 将“产品”字段添加到列区域
            PivotField columnField = pt.PivotFields["产品"];
            columnField.Axis = AxisTypes.Column;

            // 设置值字段 (数据区域)
            // 将“销售额”字段添加到数据区域,默认聚合方式为求和
            PivotField dataField = pt.PivotFields["销售额"];
            // 设置数据字段的聚合函数为求和
            dataField.Subtotals = SubtotalTypes.Sum; 
            dataField.NumberFormat = "#,##0.00"; // 设置销售额的数字格式

            // 设置筛选器 (可选)
            // 如果需要按区域筛选,可以添加筛选器字段
            // PivotField filterField = pt.PivotFields["区域"];
            // filterField.Axis = AxisTypes.Page; // Page表示筛选器区域

            // 刷新数据透视表
            pt.CalculateData();

            // 自动调整透视表所在列的宽度,使其内容完全显示
            pivotSheet.AutoFitColumns();

            Console.WriteLine("数据透视表已创建并配置完成。");

            // ... (保存文件代码)

对字段设置的详细解释:

5. 代码示例 3: 保存 Excel 文件

最后一步是将包含原始数据和数据透视表的 Excel 文件保存到指定路径。

            // ... (接上一个代码示例)

            // 保存工作簿到文件
            string outputPath = "DataPivotTableDemo.xlsx";
            workbook.SaveToFile(outputPath, ExcelVersion.Version2016); // 可以指定保存为不同版本的Excel文件

            Console.WriteLine($"Excel 文件已保存到: {System.IO.Path.GetFullPath(outputPath)}");
            Console.WriteLine("按任意键退出...");
            Console.ReadKey();
        }
    }
}

进阶应用与常见问题

进阶技巧

// get the first pivot table in the worksheet
IPivotTable pivotTable = pivotSheet.PivotTables[0];
//create a clustered column chart based on the pivot table
Chart chart = pivotSheet.Charts.Add(ExcelChartType.ColumnClustered, pivotTable);
chart.TopRow = 12;
chart.LeftColumn = 1;
chart.RightColumn = 8;
chart.BottomRow = 30;
chart.ChartTitle = "产品销售分析";
chart.PrimaryCategoryAxis.MultiLevelLable = true;
// Get the first pivot table from the sheet 
XlsPivotTable pt = pivotSheet.PivotTables[0] as XlsPivotTable;
//Disable ribbon for this pivot table
pt.EnableWizard = false;

注意事项

以上就是C#使用Spire.XLS在Excel中创建数据透视表的详细内容,更多关于C# Excel创建数据透视表的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文