使用 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 图片,满足大多数办公场景的需求。如果需要批量转换,只需遍历工作簿中的多个工作表即可。

相关推荐
瑶总迷弟3 小时前
Python入门第7章:用户输入和 while 、for循环
开发语言·python·microsoft
Allen_LVyingbo3 小时前
量子计算Dirac Notation基本教学—从零基础到读懂量子信息论文(上)
开发语言·数据结构·架构·健康医疗·量子计算
无巧不成书02183 小时前
Java变量初始化全攻略:2026最新规范+新手避坑实战
java·开发语言·java基础·java变量初始化·java语法规范·var关键字
城数派3 小时前
2014-2025年全国监测站点的逐月空气质量数据(15个指标\Excel\Shp格式)
arcgis·信息可视化·数据分析·excel
CSharp精选营3 小时前
.NET被上海信创“拉黑”了?刚子给你讲明白:别慌,这事儿没那么严重
c#·.net·信创
Highcharts.js4 小时前
企业级可视化生态系统|关于Highcharts集成的前端框架、后端编程语言与生态
开发语言·javascript·python·前端框架·编辑器·编程语言·highcharts
我头发多我先学4 小时前
C++ STL list 原理到模拟实现
开发语言·c++·list
A懿轩A4 小时前
【2026 最新】JDK 下载与安装:在 macOS 下使用 Homebrew 和 jenv 完美管理多版本 JDK
java·开发语言·jdk·mac
Wang ruoxi4 小时前
Pygame小游戏——扫雷
开发语言·python·pygame