如何使用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 天的试用许可证。

相关推荐
qq_2975746712 分钟前
【实战】POI 实现 Excel 多级表头导出(含合并单元格完整方案)
java·spring boot·后端·excel
曹牧2 天前
Excel:筛选两列中不匹配项
excel
それども2 天前
Excel文件解析 - 什么是SAX和DOM
java·excel
それども2 天前
Excel文件解析 - SAX和DOM方式的区别
java·前端·excel
それども2 天前
Excel文件解析 - SAX startRow cell endRow 执行顺序
java·前端·excel
梦因you而美2 天前
Python win32com操作Excel:彻底禁用链接更新及各类弹窗(实测有效)
python·excel·win32com·禁用链接更新·excel弹框
それども2 天前
Excel文件解析 - SAX startRow cell endRow 执行时机
java·excel
HWL56792 天前
在网页中实现WebM格式视频自动循环播放
前端·css·html·excel·音视频
开开心心就好3 天前
图片校正漂白工具永久免费,矫正实时预览
网络·人工智能·windows·计算机视觉·计算机外设·电脑·excel
开开心心_Every3 天前
音频视频转文字工具,离线语音识别免费
人工智能·游戏·微信·pdf·excel·语音识别·memcache