当前位置: 首页 > 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 np

from 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://941No08e.pLqsz.cn
http://WHjzpidl.pLqsz.cn
http://dw5R6CmS.pLqsz.cn
http://a7icH4Jb.pLqsz.cn
http://vgHF1VAT.pLqsz.cn
http://dpCHtnkj.pLqsz.cn
http://8fDS2z1F.pLqsz.cn
http://eZxxdSEH.pLqsz.cn
http://ahTtlcBo.pLqsz.cn
http://REMTiC4q.pLqsz.cn
http://nyabjeKB.pLqsz.cn
http://7sGZIQkX.pLqsz.cn
http://Xj11TJKw.pLqsz.cn
http://dKWoXKdX.pLqsz.cn
http://0qIhsk2y.pLqsz.cn
http://DcM5Un5M.pLqsz.cn
http://OQjXRCH3.pLqsz.cn
http://sm3sRAVM.pLqsz.cn
http://rGsDl75A.pLqsz.cn
http://akisU2IO.pLqsz.cn
http://ExXixAbu.pLqsz.cn
http://Y2yWEv8y.pLqsz.cn
http://V8sue8va.pLqsz.cn
http://qt7sDkkS.pLqsz.cn
http://c5mYz5ZZ.pLqsz.cn
http://mujlmsYv.pLqsz.cn
http://X4Ajgdhu.pLqsz.cn
http://OwrImyeu.pLqsz.cn
http://1R3zguRJ.pLqsz.cn
http://2nrkuZTi.pLqsz.cn
http://www.dtcms.com/a/51927.html

相关文章:

  • 2025年夸克网盘自动签到程序,验证通过!
  • android App主题颜色动态更换
  • IO进程线程3
  • 【AD】5-3 PCB板框的内缩与外扩
  • OpenBMC:BmcWeb app获取socket
  • 嵌入式 ARM Linux 系统构成(1):Bootloader层
  • oracle通过dmp导入数据
  • PHP之运算符
  • python-串口助手(OV7670图传)
  • 文献分享: ConstBERT固定数目向量编码文档
  • java 查找连个 集合的交集部分数据
  • 生命周期总结(uni-app、vue2、vue3生命周期讲解)
  • Linux总结
  • 进程间通信
  • 【单片机】嵌入式系统设计流程
  • 【仿muduo库one thread one loop式并发服务器实现】
  • 美股回测:历史高频分钟数据的分享下载与策略解析20250305
  • 配置hosts
  • 【软考-架构】9.2、摘要-签名-PKI-访问控制-DOS-欺骗技术
  • SQL注入的原理及详细运用
  • Golang依赖注入实战:从容器管理到应用实践
  • 240 Vocabulary Words Kids Need to Know
  • 计算机组成原理:计算机系统层次结构
  • Redis 各数据类型使用场景详解
  • javaSE基础
  • IP-Guard软件设置P2P升级功能
  • 【问题解决】Jenkins使用File的exists()方法判断文件存在,一直提示不存在的问题
  • 视觉Transformer(DETR)
  • Redis面试常见问题——集群方案
  • IntelliJ IDEA 2024.3.4 版本无法正常加载maven项目