C#使用Spire.XLS实现将Excel转换成高质量JPG

 更新时间:2026年04月10日 08:24:16   作者:LSTM97  
在日常办公开发中,经常遇到需要将 Excel 表格转换为图片的需求,本文主要介绍了如何使用 Spire.XLS 库,配合 C# 代码实现高质量 Excel 转 JPG,感兴趣的小伙伴可以了解下

在日常办公开发中,经常遇到需要将 Excel 表格转换为图片的需求。无论是生成报表预览、数据展示,还是防止表格格式错乱,将 Excel 转换为 JPG 都是一种实用的解决方案。今天分享如何使用 Spire.XLS 库,配合 C# 代码实现高质量 Excel 转 JPG。

为什么需要高质量转换

直接截图或使用普通转换方式,往往会导致图片模糊、文字不清晰。特别是在打印或放大查看时,低分辨率的图片根本无法满足需求。通过设置 300 DPI 的分辨率,可以确保生成的 JPG 图片清晰度达到印刷级别。

实现步骤

首先需要安装 Spire.XLS 库,通过 NuGet 包管理器搜索 Spire.XLS 即可安装。

核心代码分为三个部分:

  1. 加载 Excel 文件 :使用 Workbook 类加载指定工作表
  2. 转换为 EMF 流 :将指定区域导出为 EMF 格式的内存流
  3. 调整分辨率并保存 :通过 ResetResolution 方法将分辨率设置为 300 DPI,最终保存为 JPG

完整代码

using Spire.Xls;
using System.Drawing;
using System.Drawing.Imaging;
using System.IO;

namespace Convert
{
    class Program
    {
        static void Main(string[] args)
        {
            Workbook workbook = new Workbook();
            workbook.LoadFromFile("Input.xlsx", ExcelVersion.Version2013);
            Worksheet worksheet = workbook.Worksheets[0];

            using (MemoryStream ms = new MemoryStream())
            {
                worksheet.ToEMFStream(ms, 1, 1, worksheet.LastRow, worksheet.LastColumn);
                Image image = Image.FromStream(ms);
                Bitmap images = ResetResolution(image as Metafile, 300);
                images.Save("Result.jpg", ImageFormat.Jpeg);
            }
        }

        private static Bitmap ResetResolution(Metafile mf, float resolution)
        {
            int width = (int)(mf.Width * resolution / mf.HorizontalResolution);
            int height = (int)(mf.Height * resolution / mf.VerticalResolution);
            Bitmap bmp = new Bitmap(width, height);
            bmp.SetResolution(resolution, resolution);
            Graphics g = Graphics.FromImage(bmp);
            g.DrawImage(mf, 0, 0);
            g.Dispose();
            return bmp;
        }
    }
}

代码要点说明

  • ToEMFStream 方法可以将工作表的指定范围导出为 EMF(增强型图元文件)格式,这种矢量格式保证了放大不失真
  • ResetResolution 方法接收一个 Metafile 对象和目标分辨率,返回调整后的 Bitmap
  • 使用 MemoryStream 可以避免生成临时文件,直接在内存中完成转换

应用场景

  • 报表系统 :将数据表格生成为图片,便于嵌入 Word、PPT 或网页
  • 数据展示 :避免用户因缺少 Excel 软件而无法打开文件
  • 归档备份 :将重要表格转为图片格式,长期保存不易变样

通过上述方法,可以轻松将 Excel 表格转换为高清 JPG 图片,满足大多数办公场景的需求。如果需要批量转换,只需遍历工作簿中的多个工作表即可。

方法补充

使用 Aspose.Cells 实现转换

Aspose.Cells 是一个非常强大和稳定的 Excel 文件操作库,同样支持高质量的渲染。

操作步骤:

  • 安装:在 NuGet 包管理器中搜索 Aspose.Cells 并安装。
  • 加载文件并设置选项:创建 Workbook 对象,并用 ImageOrPrintOptions 配置输出格式和 DPI。
  • 渲染工作表:使用 SheetRender 对象将工作表渲染为 Bitmap
  • 保存图片:调用 Save 方法将图片保存为 JPG 文件。

下面是具体的 C# 代码实现

using Aspose.Cells;
using Aspose.Cells.Rendering;
using System.Drawing;
class Program
{
    static void Main()
    {
        // 1. 加载 Excel 文件
        Workbook workbook = new Workbook("测试.xlsx");
        Worksheet worksheet = workbook.Worksheets[0];
        // 2. 配置图像渲染选项
        ImageOrPrintOptions options = new ImageOrPrintOptions();
        options.ImageType = Drawing.ImageType.Jpeg;
        options.OnePagePerSheet = true;
        // 可选:设置高分辨率,确保高质量
        options.HorizontalResolution = 300;
        options.VerticalResolution = 300;
        // 3. 渲染工作表
        SheetRender render = new SheetRender(worksheet, options);
        Bitmap bitmap = render.ToImage(0);
        // 4. 保存为 JPG 图片
        bitmap.Save("输出结果.jpg");
    }
}

重要提示

  • 拒绝 Interop:虽然 Microsoft.Office.Interop.Excel 可以免费使用,但它会直接调用本地 Excel 程序,存在稳定性差、内存泄漏和依赖 Excel 环境的严重问题。强烈不推荐在生产环境(如 Web 服务)中使用
  • 获取临时许可证:上述代码示例中的商用库(Spire.XLS 和 Aspose.Cells)在评估模式下可能会在输出图片上添加水印或限制行数。建议前往官方申请一个临时许可证来消除这些限制。
  • 处理好路径与权限:确保你的程序对目标文件夹有写入权限,以免保存图片时出错。此外,务必确认输入文件的路径是正确的。
  • 探索进阶功能:除了转换整个工作表,这些库通常还支持将工作簿、特定图表或单元格区域转换为图片。你可以根据实际需求查阅官方文档。

到此这篇关于C#使用Spire.XLS实现将Excel转换成高质量JPG的文章就介绍到这了,更多相关C# Excel转JPG内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C# try catch代码块不起效果的解决方法

    C# try catch代码块不起效果的解决方法

    本文主要介绍了C# try catch代码块不起效果的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • C#简单实现发送socket字符串

    C#简单实现发送socket字符串

    这篇文章主要为大家详细介绍了C#简单实现socket字符串发送,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • 基于WPF制作一个可编程画板

    基于WPF制作一个可编程画板

    这篇文章主要为大家详细介绍了如何基于WPF制作一个可编程画板,文中的示例代码讲解详细,对我们学习或工作有一定帮助,感兴趣的小伙伴可以了解一下
    2023-05-05
  • C#手动操作DataGridView使用各种数据源填充表格实例

    C#手动操作DataGridView使用各种数据源填充表格实例

    本文主要介绍了C#手动操作DataGridView使用各种数据源填充表格实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • 关于C#中的Invoke示例详解

    关于C#中的Invoke示例详解

    一直对invoke和begininvoke的使用和概念比较混乱,这两天看了些资料,对这两个的用法和原理有了些新的认识和理解,下面这篇文章主要给大家介绍了关于C#中Invoke的相关资料,需要的朋友可以参考下
    2023-02-02
  • C#实现多文件压缩与解压功能

    C#实现多文件压缩与解压功能

    这篇文章主要为大家详细介绍了如何利用C#语言实现多文件压缩与解压功能,即选择多个文件压缩成ZIP文件和解压ZIP文件,需要的可以参考一下
    2022-08-08
  • C#中倒计时功能的优化方法小结

    C#中倒计时功能的优化方法小结

    这篇文章主要为大家详细介绍了当C#重复使用一段代码倒计时时,如何使用普通类和静态方法,实现简单的代码封装性、可扩展性、可维护性,感兴趣的可以了解下
    2024-01-01
  • 详解Unity日志打印工具功能

    详解Unity日志打印工具功能

    Unity是一个非常火的游戏引擎,我们再开发的时候有的时候要进行程序的调试,下面给大家介绍下Unity日志打印工具功能,感兴趣的朋友一起看看吧
    2022-01-01
  • Unity UGUI的Canvas画布组件使用示例详解

    Unity UGUI的Canvas画布组件使用示例详解

    这篇文章主要介绍了Unity UGUI的Canvas画布组件使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • Entity Framework主从表数据加载方式

    Entity Framework主从表数据加载方式

    这篇文章介绍了Entity Framework主从表数据加载方式,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06

最新评论