使用C#代码在 PowerPoint 中创建组合图表
在 PowerPoint 中,组合图表是一种将两种或多种不同图表类型合并到同一图表中的图表形式。它可以在一个图表中展示多组数据,使不同变量之间的对比和分析更加直观。在本文中,你将学习如何通过编程方式在 PowerPoint 演示文稿中创建组合图表。 在开始之前,你需要在 .NET 项目中添加相关组件作为引用。这些组件可以通过下载安装包获取,也可以通过 NuGet 进行安装。 在 PowerPoint 中,可以先向幻灯片中添加一种基础图表类型,然后将其中某个数据系列更改为另一种图表类型,从而实现组合图表的效果。下面是将柱形图与折线图组合的基本步骤: 示例代码如下: 总的来说,组合图表是一种非常实用的数据可视化方式,能够在同一图表中同时展示不同类型的数据,从而提升信息表达的清晰度和对比效果。通过本文的示例,可以看到,在 PowerPoint 中实现柱形图与折线图的组合并不复杂:核心思路是先创建基础图表,再对特定数据系列调整图表类型,并结合次坐标轴来呈现不同量级的数据。 整个过程涵盖了数据准备、图表配置以及样式优化等关键步骤,不仅可以满足基础的数据展示需求,还能通过标题、图例、坐标轴等细节设置提升图表的可读性和专业度。掌握这种方法后,你可以根据实际业务场景灵活扩展,构建更符合需求的数据可视化效果。环境准备
PM> Install-Package Spire.Presentation在 C# 和 VB.NET 中创建 PowerPoint 组合图表
using Spire.Presentation;
using Spire.Presentation.Charts;
using Spire.Presentation.Drawing;
using System;
using System.Data;
using System.Drawing;
namespace CombinationChart
{
class Program
{
static void Main(string[] args)
{
// 创建一个 Presentation 实例
Presentation presentation = new Presentation();
// 在第一张幻灯片中添加一个簇状柱形图
RectangleF rect = new RectangleF(80, 120, 550, 320);
IChart chart = presentation.Slides[0].Shapes.AppendChart(ChartType.ColumnClustered, rect);
// 设置并格式化图表标题
chart.ChartTitle.TextProperties.Text = "Monthly Sales Report"; // 月度销售报告
chart.ChartTitle.TextProperties.IsCentered = true;
chart.ChartTitle.Height = 30;
chart.HasTitle = true;
// 创建一个 DataTable 并添加数据
DataTable dataTable = new DataTable();
dataTable.Columns.Add(new DataColumn("Month", Type.GetType("System.String"))); // 月份
dataTable.Columns.Add(new DataColumn("Sales", Type.GetType("System.Int32"))); // 销售额
dataTable.Columns.Add(new DataColumn("Growth rate", Type.GetType("System.Decimal"))); // 增长率
dataTable.Rows.Add("January", 200, 0.6);
dataTable.Rows.Add("February", 250, 0.8);
dataTable.Rows.Add("March", 300, 0.6);
dataTable.Rows.Add("April", 150, 0.2);
dataTable.Rows.Add("May", 200, 0.5);
dataTable.Rows.Add("June", 400, 0.9);
// 将 DataTable 中的数据导入到图表
for (int c = 0; c < dataTable.Columns.Count; c++)
{
chart.ChartData[0, c].Text = dataTable.Columns[c].Caption;
}
for (int r = 0; r < dataTable.Rows.Count; r++)
{
object[] datas = dataTable.Rows[r].ItemArray;
for (int c = 0; c < datas.Length; c++)
{
chart.ChartData[r + 1, c].Value = datas[c];
}
}
// 设置系列标签
chart.Series.SeriesLabel = chart.ChartData["B1", "C1"];
// 设置分类标签
chart.Categories.CategoryLabels = chart.ChartData["A2", "A7"];
// 为系列赋值
chart.Series[0].Values = chart.ChartData["B2", "B7"];
chart.Series[1].Values = chart.ChartData["C2", "C7"];
// 将第二个系列的图表类型改为带数据标记的折线图
chart.Series[1].Type = ChartType.LineMarkers;
// 将第二个系列绘制在次坐标轴上
chart.Series[1].UseSecondAxis = true;
// 设置次坐标轴的数字格式
chart.SecondaryValueAxis.NumberFormat = "0%";
// 隐藏次坐标轴的网格线
chart.SecondaryValueAxis.MajorGridTextLines.FillType = FillFormatType.None;
// 设置图例位置
chart.ChartLegend.Position = ChartLegendPositionType.Top;
// 设置柱形图重叠比例
chart.OverLap = -50;
// 设置柱间距
chart.GapWidth = 200;
// 保存结果文档
presentation.SaveToFile("CombinationChart.pptx", FileFormat.Pptx2010);
}
}
}结语