C#代码实现在Excel中创建雷达图

 更新时间:2026年05月11日 08:34:33   作者:2501_93070778  
本文演示了如何在 C# 中创建填充型雷达图,通过设置数据、样式与图表属性,实现多维数据的可视化展示,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下

Excel 雷达图(也称为蜘蛛图或网络图)用于在不同类别中比较多个数据系列。通过在多轴坐标上绘制数据点,雷达图能够直观清晰地展示数据的均衡性与偏差情况,因此常用于绩效指标分析、市场数据对比等需要多维度比较的场景。本文将介绍如何在 C# 中实现 Excel 雷达图的创建方法。

  • 在 Excel 中创建简单雷达图
  • 在 Excel 中创建填充型雷达图

环境准备

在开始之前,需要在 .NET 项目中引入相关 DLL 依赖,可通过 NuGet 或下载方式添加到项目中进行引用。

PM> Install-Package Spire.XLS

在 Excel 中创建简单雷达图(C#)

可以通过在工作表中添加雷达图类型来实现标准雷达图的创建,整体流程如下:

  1. 创建一个 Workbook 工作簿实例。
  2. 通过 Workbook.Worksheets[sheetIndex] 获取指定工作表。
  3. 在单元格中填充图表数据并设置相应的单元格样式。
  4. 在工作表中添加雷达图类型(Radar Chart)。
  5. 为图表设置数据区域(Data Range)。
  6. 调整图表的位置,并设置图例和标题。
  7. 将生成的 Excel 文件保存到指定路径。

示例代码如下:

using Spire.Xls;
using System.Drawing;

namespace ExcelRadarChart
{
    class Program
    {
        static void Main(string[] args)
        {
            // 创建一个工作簿实例
            Workbook workbook = new Workbook();

            // 获取第一个工作表
            Worksheet sheet = workbook.Worksheets[0];

            // 向指定单元格添加图表数据
            sheet.Range["A1"].Value = "评分维度";
            sheet.Range["A2"].Value = "沟通能力";
            sheet.Range["A3"].Value = "经验";
            sheet.Range["A4"].Value = "工作效率";
            sheet.Range["A5"].Value = "领导力";
            sheet.Range["A6"].Value = "解决问题能力";
            sheet.Range["A7"].Value = "团队合作";

            sheet.Range["B1"].Value = "Jonathan";
            sheet.Range["B2"].NumberValue = 4;
            sheet.Range["B3"].NumberValue = 3;
            sheet.Range["B4"].NumberValue = 4;
            sheet.Range["B5"].NumberValue = 3;
            sheet.Range["B6"].NumberValue = 5;
            sheet.Range["B7"].NumberValue = 5;

            sheet.Range["C1"].Value = "Ryan";
            sheet.Range["C2"].NumberValue = 2;
            sheet.Range["C3"].NumberValue = 5;
            sheet.Range["C4"].NumberValue = 4;
            sheet.Range["C5"].NumberValue = 4;
            sheet.Range["C6"].NumberValue = 3;
            sheet.Range["C7"].NumberValue = 3;

            // 设置字体样式
            sheet.Range["A1:C1"].Style.Font.IsBold = true;
            sheet.Range["A1:C1"].Style.Font.Size = 11;
            sheet.Range["A1:C1"].Style.Font.Color = Color.White;

            // 设置行高和列宽
            sheet.Rows[0].RowHeight = 20;
            sheet.Range["A1:C7"].Columns[0].ColumnWidth = 15;

            // 设置单元格样式
            sheet.Range["A1:C1"].Style.Color = Color.DarkBlue;
            sheet.Range["A2:C7"].Borders[BordersLineType.EdgeBottom].LineStyle = LineStyleType.Thin;
            sheet.Range["A2:C7"].Style.Borders[BordersLineType.EdgeBottom].Color = Color.DarkBlue;
            sheet.Range["B1:C7"].HorizontalAlignment = HorizontalAlignType.Center;
            sheet.Range["A1:C7"].VerticalAlignment = VerticalAlignType.Center;

            // 在工作表中添加雷达图
            Chart chart = sheet.Charts.Add(ExcelChartType.Radar);

            // 设置图表位置
            chart.LeftColumn = 4;
            chart.TopRow = 4;
            chart.RightColumn = 14;
            chart.BottomRow = 29;

            // 设置图表的数据区域
            chart.DataRange = sheet.Range["A1:C7"];
            chart.SeriesDataFromRange = false;

            // 设置并格式化图表标题
            chart.ChartTitle = "员工绩效考核";
            chart.ChartTitleArea.IsBold = true;
            chart.ChartTitleArea.Size = 14;

            // 设置图例位置
            chart.Legend.Position = LegendPositionType.Corner;

            // 保存生成的 Excel 文件
            workbook.SaveToFile("ExcelRadarChart.xlsx", ExcelVersion.Version2016);
        }
    }
}

在 Excel 中创建填充型雷达图(C#)

填充型雷达图是标准雷达图的一种变体,其特点是在每个数据点之间的区域填充颜色,更直观地展示数据的分布情况。使用 C# 创建填充型雷达图的步骤如下:

  1. 创建一个工作簿实例。
  2. 通过 Workbook.Worksheets[sheetIndex] 获取指定工作表。
  3. 在单元格中添加图表数据,并设置单元格样式。
  4. 在工作表中添加填充型雷达图(Filled Radar Chart)。
  5. 设置图表的数据范围(Data Range)。
  6. 调整图表位置,并设置图例和标题。
  7. 将生成的 Excel 文件保存到指定路径。

示例代码如下:

using Spire.Xls;
using System.Drawing;

namespace ExcelRadarChart
{
    class Program
    {
        static void Main(string[] args)
        {
            // 创建一个工作簿实例
            Workbook workbook = new Workbook();

            // 获取第一个工作表
            Worksheet sheet = workbook.Worksheets[0];

            // 在指定单元格中添加图表数据
            sheet.Range["A1"].Value = "评分维度";
            sheet.Range["A2"].Value = "沟通能力";
            sheet.Range["A3"].Value = "经验";
            sheet.Range["A4"].Value = "工作效率";
            sheet.Range["A5"].Value = "领导力";
            sheet.Range["A6"].Value = "解决问题能力";
            sheet.Range["A7"].Value = "团队合作";

            sheet.Range["B1"].Value = "Jonathan";
            sheet.Range["B2"].NumberValue = 4;
            sheet.Range["B3"].NumberValue = 3;
            sheet.Range["B4"].NumberValue = 4;
            sheet.Range["B5"].NumberValue = 3;
            sheet.Range["B6"].NumberValue = 5;
            sheet.Range["B7"].NumberValue = 5;

            sheet.Range["C1"].Value = "Ryan";
            sheet.Range["C2"].NumberValue = 2;
            sheet.Range["C3"].NumberValue = 5;
            sheet.Range["C4"].NumberValue = 4;
            sheet.Range["C5"].NumberValue = 4;
            sheet.Range["C6"].NumberValue = 3;
            sheet.Range["C7"].NumberValue = 3;

            // 设置字体样式
            sheet.Range["A1:C1"].Style.Font.IsBold = true;
            sheet.Range["A1:C1"].Style.Font.Size = 11;
            sheet.Range["A1:C1"].Style.Font.Color = Color.White;

            // 设置行高和列宽
            sheet.Rows[0].RowHeight = 20;
            sheet.Range["A1:C7"].Columns[0].ColumnWidth = 15;

            // 设置单元格样式
            sheet.Range["A1:C1"].Style.Color = Color.DarkBlue;
            sheet.Range["A2:C7"].Borders[BordersLineType.EdgeBottom].LineStyle = LineStyleType.Thin;
            sheet.Range["A2:C7"].Style.Borders[BordersLineType.EdgeBottom].Color = Color.DarkBlue;
            sheet.Range["B1:C7"].HorizontalAlignment = HorizontalAlignType.Center;
            sheet.Range["A1:C7"].VerticalAlignment = VerticalAlignType.Center;

            // 在工作表中添加填充型雷达图
            Chart chart = sheet.Charts.Add(ExcelChartType.RadarFilled);

            // 设置图表位置
            chart.LeftColumn = 4;
            chart.TopRow = 4;
            chart.RightColumn = 14;
            chart.BottomRow = 29;

            // 设置图表的数据范围
            chart.DataRange = sheet.Range["A1:C7"];
            chart.SeriesDataFromRange = false;

            // 设置并格式化图表标题
            chart.ChartTitle = "员工绩效考核";
            chart.ChartTitleArea.IsBold = true;
            chart.ChartTitleArea.Size = 14;

            // 设置图例位置
            chart.Legend.Position = LegendPositionType.Corner;

            // 保存生成的 Excel 文件
            workbook.SaveToFile("FilledRadarChart.xlsx", ExcelVersion.Version2016);
        }
    }
}

总结

本文演示了如何在 C# 中创建填充型雷达图,通过设置数据、样式与图表属性,实现多维数据的可视化展示。整个过程包括工作簿创建、数据填充、样式调整、图表生成以及文件保存,步骤清晰且易于实现。

填充型雷达图能够直观对比多个指标的差异,适用于绩效评估、数据分析等多维度场景,帮助更高效地呈现和理解数据。

到此这篇关于C#代码实现在Excel中创建雷达图的文章就介绍到这了,更多相关C# Excel创建雷达图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#二叉搜索树算法实现步骤和实例代码

    C#二叉搜索树算法实现步骤和实例代码

    二叉搜索树(Binary Search Tree,简称BST)是一种节点有序排列的二叉树数据结构,这篇文章主要介绍了C#二叉搜索树算法实现步骤和实例代码,需要的朋友可以参考下
    2024-08-08
  • C#实现数据去重的方式总结

    C#实现数据去重的方式总结

    这篇文章主要来和大家一起来讨论一下关于C#数据去重的常见的几种方式,每种方法都有其特点和适用场景,感兴趣的小伙伴可以了解一下
    2023-07-07
  • C# 10分钟完成百度人脸识别(入门篇)

    C# 10分钟完成百度人脸识别(入门篇)

    这篇文章主要介绍了C# 10分钟完成百度人脸识别(入门篇),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-02-02
  • 解析如何正确使用SqlConnection的实现方法

    解析如何正确使用SqlConnection的实现方法

    本篇文章对如何正确使用SqlConnection的实现方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • unity 切换场景不销毁物体问题的解决

    unity 切换场景不销毁物体问题的解决

    这篇文章主要介绍了unity 切换场景不销毁物体问题的解决方案,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • 深入理解C# abstract和virtual关键字

    深入理解C# abstract和virtual关键字

    深入理解C# abstract和virtual关键字,学习c#的朋友可以参考下。
    2011-06-06
  • c#之事件用法

    c#之事件用法

    这篇文章介绍了c#中事件的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • C#生成不重复随机数列表实例

    C#生成不重复随机数列表实例

    C#生成不重复随机数列表实例的代码,需要的朋友可以参考一下
    2013-02-02
  • C# 如何使用批处理启动Windows服务

    C# 如何使用批处理启动Windows服务

    这篇文章主要介绍了C#使用批处理启动Windows服务,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • C#实现逐行读取和写入文件的方法

    C#实现逐行读取和写入文件的方法

    这篇文章给大家介绍了使用C#语言实现同样的功能,即从输入文件中读取每行数据,然后将每行字段组合成SQL插入脚本,然后逐行写入另外一个空白文件中,感兴趣的朋友可以参考下
    2024-01-01

最新评论