当前位置: 首页 > news >正文

利用opencv_python(pdf2image、poppler)将pdf每页转为图片

1、安装依赖pdf2image

pip install pdf2image

运行.py报错,因为缺少了poppler支持。

2、安装pdf2image的依赖poppler

以上命令直接报错。

改为手工下载:

github:

Releases · oschwartz10612/poppler-windows · GitHub

百度网盘:

百度网盘 请输入提取码

提取码:5cxx

下载后,解压目录,并且将bin目录加入到环境变量中:

这里要重启IDE后才可以生效,我用的是Spyder6。

3、编写代码

# -*- coding: utf-8 -*-
"""
Created on Sun Mar  2 20:34:25 2025@author: 花花鱼"""
import cv2
import numpy as npfrom pdf2image import convert_from_path# 将 PDF 文件转换为图像,返回图像列表
images = convert_from_path('D:\\opencv\\pdf\\test.pdf')for i, image in enumerate(images):# 将 PIL 图片转换为 OpenCV 格式opencv_image = cv2.cvtColor(np.array(image), cv2.COLOR_RGB2BGR)# 转换为灰度图像gray_image = cv2.cvtColor(opencv_image, cv2.COLOR_BGR2GRAY)# 应用二值化处理_, binary_image = cv2.threshold(gray_image, 200, 255, cv2.THRESH_BINARY_INV)# 使用形态学操作去掉小的水印噪声kernel = np.ones((3, 3), np.uint8)processed_image = cv2.morphologyEx(binary_image, cv2.MORPH_OPEN, kernel)# 保存处理后的图像cv2.imwrite(f'D:\\opencv\\pdf\\output_page_{i + 1}.png', processed_image)

4、运行

5、生成的图片的效果

我们会发现图片已经生成了,并且还是黑底的,下面就可以将图片进行处理了,比较去掉水印啊,加上一些元素啊,以达到我们的要求。

有兴趣的小伙伴可以自己找个pdf去测试下,我相信你会感受到python的魅力。


http://www.mrgr.cn/news/92865.html

相关文章:

  • vcpkg 与 CMake 集成的步骤
  • Hadoop之02:MR-图解
  • Ollama运行各种平台的大模型(deepseek),配合AnythingLLM-UI界面使用
  • 高频 SQL 50 题(基础版)_550. 游戏玩法分析 IV
  • ZYNQ-PL实践课堂(四)IP核之RAM
  • 多Agent协作智能系统
  • C++(6)内存管理
  • 了解什么是红黑树
  • 【Linux】进程信号
  • The “Rule-of-Zero“ should be followed (s4963)
  • Hadoop之01:HDFS分布式文件系统
  • I2C驱动(十一) -- gpio模拟的i2c总线驱动i2c-gpio.c分析
  • 第一个Vue项目笔记(待更新)
  • 250301-OpenWebUI配置DeepSeek-火山方舟+硅基流动+联网搜索+推理显示
  • C语言学习笔记-初阶(19)猜数字游戏:分支、循环结构的应用
  • 大数据学习(51)-MySQL数据库学习
  • IP-----双重发布
  • ConcurrentHashMap
  • 初始化列表
  • 详解:事务注解 @Transactional