.NET 开发中如何通过 C# 提取 PDF 中的图片

 更新时间:2026年02月03日 08:44:33   作者:LAYONTHEGROUND  
本文介绍了如何使用FreeSpire.PDFfor.NET免费库从PDF文档中提取图片,提供了两种典型场景的代码示例,并强调了该方案的优势,包括灵活可控、高效批量处理和轻量无依赖,感兴趣的朋友跟随小编一起看看吧

在.NET 开发中,从 PDF 里提取图片是个高频需求 —— 不管是数据迁移时需要剥离文档中的图表,还是内容分析时要提取关键插图,都绕不开这个场景。但传统方案总有些麻烦:付费 PDF 库成本高,还可能依赖 Adobe Acrobat 这类重型工具,对中小型项目不够友好。
本文将介绍如何使用免费库 Free Spire.PDF for .NET 精准实现“整文档批量提取”或“指定页面精准提取”,代码简单、操作高效。

一、前期准备:快速引入工具库

使用 Free Spire.PDF 前,需先完成库引用,推荐通过 NuGet 安装(步骤极简,3步即可完成):

  • 打开Visual Studio,右键项目选择“管理NuGet程序包”;
  • 在“浏览”栏搜索“Free Spire.PDF”,找到官方包后点击“安装”;
  • 等待安装完成,项目会自动添加引用,无需手动配置路径。

⚠️ 注意:免费版对单文档页数有一定限制。

二、核心逻辑与场景实现

Free Spire.PDF 提取图片的核心逻辑很清晰:通过 PdfImageHelper 类的 GetImagesInfo() 方法获取页面图片信息,再调用 PdfImageInfo.Image.Save() 保存图片。以下针对两种典型场景,提供可直接复用的代码。

场景1:提取 PDF 文档中所有图片

适用于需要批量获取文档中所有图片的场景(例如归档文档内所有插图等)。实现逻辑为“加载文档→遍历所有页面→提取并按序保存图片”。

using Spire.Pdf;
using Spire.Pdf.Utilities;
using System.Drawing;
namespace ExtractAllImages
{
    class Program
    {
        static void Main(string[] args)
        {
            // 1. 加载目标PDF文档
            PdfDocument pdf = new PdfDocument();
            pdf.LoadFromFile("Input.pdf"); // 替换为你的PDF路径
            // 2. 初始化图片处理工具
            PdfImageHelper imageHelper = new PdfImageHelper();
            // 3. 遍历所有页面,提取图片
            int imageCount = 0; // 用于给图片命名,避免重复
            for (int pageIndex = 0; pageIndex < pdf.Pages.Count; pageIndex++)
            {
                // 获取当前页对象
                PdfPageBase currentPage = pdf.Pages[pageIndex];
                // 获取当前页所有图片信息
                PdfImageInfo[] imageInfos = imageHelper.GetImagesInfo(currentPage);
                // 保存当前页的图片
                foreach (var imageInfo in imageInfos)
                {
                    Image image = imageInfo.Image;
                    // 保存路径可自定义
                    image.Save($"Output\\image_{imageCount}.png"); 
                    imageCount++;
                }
            }
            // 4. 释放资源
            pdf.Dispose();
        }
    }
}

场景2:提取 PDF 指定页面的图片

适用于仅需某几页图片的场景(例如从多页报告中提取封面图、从论文中提取某页的图表等)。核心是“定位目标页面→单独提取该页图片”。

⚠️ 关键提醒:Free Spire.PDF 的页面索引从0开始(第1页对应索引0,第2页对应索引1,以此类推)。

using Spire.Pdf;
using Spire.Pdf.Utilities;
using System.Drawing;
namespace ExtractImagesFromSpecificPage
{
    class Program
    {
        static void Main(string[] args)
        {
            // 1. 加载目标PDF文档
            PdfDocument pdf = new PdfDocument();
            pdf.LoadFromFile("Input.pdf"); // 替换为你的PDF路径
            // 2. 定位指定页面(此处以第1页为例,索引为0)
            int targetPageIndex = 0; // 如需提取第3页,改为2即可
            PdfPageBase targetPage = pdf.Pages[targetPageIndex];
            // 3. 初始化图片处理工具并获取图片信息
            PdfImageHelper imageHelper = new PdfImageHelper();
            PdfImageInfo[] imageInfos = imageHelper.GetImagesInfo(targetPage);
            // 4. 保存指定页的图片
            for (int i = 0; i < imageInfos.Length; i++)
            {
                Image image = imageInfos[i].Image;
                // 保存路径可自定义
                image.Save($"Output\\page_{targetPageIndex + 1}_image_{i}.png"); 
            }
            // 5. 释放资源
            pdf.Dispose();
        }
    }
}

三、方案优势与注意事项

  • 灵活可控:支持自定义图片保存路径(如Output\\)和格式(如 PNGJPG 等);
  • 高效批量处理:通过循环逻辑可快速处理多页 PDF,无需手动逐页操作;
  • 轻量无依赖:无需安装 Adobe Acrobat 等第三方软件,仅需引用一个类库即可运行。

总结

用 Free Spire.PDF for .NET 提取PDF图片,无需编写复杂解析算法,也不用依赖重型工具,几行代码即可实现精准提取。无论是整文档批量处理,还是指定页面定向提取,都能轻松应对。

到此这篇关于 .NET 开发中如何通过 C# 提取 PDF 中的图片的文章就介绍到这了,更多相关C# 提取 PDF图片内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何:对Windows 窗体控件进行线程安全调用

    如何:对Windows 窗体控件进行线程安全调用

    使用多线程提高 Windows 窗体应用程序的性能时,必须注意以线程安全方式调用控件。
    2007-03-03
  • C#基础 延迟加载介绍与实例

    C#基础 延迟加载介绍与实例

    C#基础 延迟加载介绍与实例,有效使用它可以大大提高系统性能,需要的朋友可以参考一下
    2013-04-04
  • C#中环境变量示例详解

    C#中环境变量示例详解

    环境变量是操作系统中存储的一种机制,用于保存与操作系统环境和应用程序运行相关的配置信息,在 C# 中,可以使用 Environment.GetEnvironmentVariable 方法来获取特定环境变量的值,下面给大家介绍C#中环境变量示例代码,一起看看吧
    2024-05-05
  • C#实现NPOI的Excel导出详解

    C#实现NPOI的Excel导出详解

    这篇文章主要介绍了C#实现NPOI的Excel导出的示例代码,文中的实现过程讲解详细,对我们的学习或工作有一定的帮助,感兴趣的可以跟随小编一起学习一下
    2022-01-01
  • C#中String和StringBuilder的简介与区别

    C#中String和StringBuilder的简介与区别

    今天小编就为大家分享一篇关于C#中String和StringBuilder的简介与区别,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10
  • c#使用微信接口开发微信门户应用

    c#使用微信接口开发微信门户应用

    本系列文章希望从一个循序渐进的角度上,全面介绍微信的相关开发过程和相关经验总结,希望给大家了解一下相关的开发历程。
    2014-03-03
  • C#统计字符串中数字个数的方法

    C#统计字符串中数字个数的方法

    这篇文章主要介绍了C#统计字符串中数字个数的方法,涉及C#遍历字符串并判断数字的技巧,需要的朋友可以参考下
    2015-06-06
  • c#开发的程序安装时动态指定windows服务名称

    c#开发的程序安装时动态指定windows服务名称

    前段时间由于项目的需求,要在Windows里把同样的组件制作成多个不同名称的服务,这些服务完成类似的功能,仅需要修改业务配置文件
    2012-06-06
  • 跳一跳自动跳跃C#代码实现

    跳一跳自动跳跃C#代码实现

    这篇文章主要为大家详细介绍了跳一跳自动跳跃C#代码实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • C#代码实现在Excel中隐藏或显示网格线

    C#代码实现在Excel中隐藏或显示网格线

    网格线是 Excel 工作表中用于区分单元格的浅色线条,本文将介绍如何使用 Spire.XLS for .NET 通过代码的方式显示、隐藏或移除 Excel 工作表中的网格线,感兴趣的小伙伴可以了解下
    2026-01-01

最新评论