如何使用C#代码将 Excel 中的图表转换为图片

图表通常用于 Microsoft Excel 文件中,以可视化展示数值数据。在某些情况下,您可能需要将 Excel 文件中的图表保存为图片,以便在其他程序或文件中使用,例如 PDF 和 PowerPoint 演示文稿。本文将演示如何使用 Spire.XLS for .NET,通过 C# 和 VB.NET 将 Excel 中的图表转换为图片。

安装 Spire.XLS for .NET

首先,您需要将 Spire.XLS for .NET 软件包中包含的 DLL 文件添加为 .NET 项目的引用。这些 DLL 文件可以通过此链接下载,或通过 NuGet 进行安装。

cs 复制代码
PM> Install-Package Spire.XLS

在 C# 和 VB.NET 中将 Excel 工作表中的指定图表转换为图片

Spire.XLS 提供了 Workbook.SaveChartAsImage(Worksheet worksheet, int chartIndex) 方法,可用于将工作表中的指定图表转换为图片。

示例代码如下:

cs 复制代码
using Spire.Xls;
using System.Drawing;
using System.Drawing.Imaging;

namespace ConvertAExcelChartToImage
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 初始化 Workbook 类的实例
            Workbook workbook = new Workbook();
            // 加载示例 Excel 文件
            workbook.LoadFromFile("Charts.xlsx");

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

            // 将第一个工作表中的第一个图表保存为图片
            Image image = workbook.SaveChartAsImage(sheet, 0);
            // 将图片保存为 .png 文件
            image.Save(@"output\chart.png", ImageFormat.Png);
        }
    }
}

在 C# 和 VB.NET 中将 Excel 工作表中的所有图表转换为图片

要将 Excel 工作表中的所有图表转换为图片,可以使用 Workbook.SaveChartAsImage(Worksheet worksheet) 方法。

示例代码如下:

cs 复制代码
using Spire.Xls;
using System.Drawing;
using System.Drawing.Imaging;

namespace ConvertAllExcelChartsToImages
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 初始化 Workbook 类的实例
            Workbook workbook = new Workbook();
            // 加载示例 Excel 文件
            workbook.LoadFromFile("Charts.xlsx");

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

            // 将第一个工作表中的所有图表保存为图片
            Image[] imgs = workbook.SaveChartAsImage(sheet);

            // 将图片保存为 png 文件
            for (int i = 0; i < imgs.Length; i++)
            {
                imgs[i].Save(string.Format(@"output\chart-{0}.png", i), ImageFormat.Png);
            }
        }
    }
}

在 C# 和 VB.NET 中将 Excel 中的图表工作表转换为图片

您可以使用 Workbook.SaveChartAsImage(ChartSheet chartSheet) 方法,将 Excel 中的图表工作表转换为图片。

示例代码如下:

cs 复制代码
using Spire.Xls;
using System.Drawing;
using System.Drawing.Imaging;

namespace ConvertExcelChartSheetToImage
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 初始化 Workbook 类的实例
            Workbook workbook = new Workbook();
            // 加载示例 Excel 文件
            workbook.LoadFromFile("ChartSheet.xlsx");

            // 获取第一个图表工作表
            ChartSheet chartSheet = workbook.Chartsheets[0];

            // 将第一个图表工作表保存为图片
            Image image = workbook.SaveChartAsImage(chartSheet);
            // 将图片保存为 .png 文件
            image.Save(@"output\chartSheet.png", ImageFormat.Png);            
        }
    }
}

申请临时许可证

如果您希望删除生成文档中的评估消息,或解除功能限制,请为自己申请一份有效期为 30 天的试用许可证。

相关推荐
Mr.456713 小时前
Spring Boot 3 + EasyExcel 3.x 实战:构建高效、可靠的Excel导入导出服务
spring boot·后端·excel
如意机反光镜裸13 小时前
excel怎么快速导入oracle
数据库·oracle·excel
开开心心就好15 小时前
免费轻量级PDF阅读器,打开速度快
windows·计算机视觉·visualstudio·pdf·计算机外设·excel·myeclipse
城数派1 天前
2015-2025年我国区县逐年二手房房价数据(Excel/Shp格式)
excel
用户8356290780511 天前
Python 设置 Excel 条件格式教程
后端·python·excel
lzksword1 天前
关于EXCEL中vlookup身份证匹配失败的处理
excel
城数派1 天前
1990-2025年我国省市县三级的逐年土地覆盖数据(9类用地/Excel/Shp格式)
excel
catoop2 天前
构建高稳健性、可交互的复杂 Excel 报表方法论:切片、流式与动态公式
excel
葡萄城技术团队2 天前
Excel VBA 核心概念全解析:宏、模块、过程的区别与联系(含 SpreadJS Web 替代方案)
excel