百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

python使用fitz模块提取pdf中的图片

liuian 2024-12-29 04:28 368 浏览

原以为这是一件很简单的过程,在百度上搜寻无果后。于是去查找官方文档,根据官方文档

https://pymupdf.readthedocs.io/en/latest/module.html#extracting-fonts-and-images

测试发现确实能够提取相应的图片信息

python -m fitz extract -h
usage: fitz extract [-h] [-images] [-fonts] [-output OUTPUT] [-password PASSWORD]
[-pages PAGES]
input
 
--------------------- extract images and fonts to disk --------------------
 
positional arguments:
input PDF filename
 
optional arguments:
-h, --help show this help message and exit
-images extract images
-fonts extract fonts
-output OUTPUT output directory, defaults to current
-password PASSWORD password
-pages PAGES only consider these pages, format: 1,5-7,50-N

但是在使用pycharm调试过程中报错

AttributeError: module 'fitz' has no attribute 'open'

于是找到"fitz\__main__.py"文件复制出来单独运行,运行一切正常

在看源码过程中

发下python中居然还会有作者关心内存的释放,这是我在写java和python过程中从没考虑的问题。

通过这种方式能够将文件中的图片抽取出来,但是不能找到图片被引用的具体信息,例如位置和引用次数。

python比Java方便的是,对于引用的包可以通过pycharm直接查看源码,于是继续搜寻源码看看在哪里可以找到有用的信息。

在搜寻过程中找到get_image_info这个函数,里面会描述图片所在位置的具体位置信息.

整理后的具体代码如下

import fitz
import cv2
import numpy as np
import utils.pymupdf_utils as pdf_util

path = r'南大路.pdf'
#加载pdf文件,可以参考源码中的open_file
doc = fitz.open(path)
#获取当前页的图片文件,可以用下面两种方式,也可以用for循环遍历每一页
# img_list = doc.get_page_images(0)
img_list = doc[0].getImageList()
for item in img_list:
    #提取图片字典,recoverpix函数参考__main__.py
    img_dict = pdf_util.recoverpix(doc, item)
    width, height, data = img_dict['width'], img_dict['height'], img_dict['image']
    # 将字节数组转为np格式数据
    np_data = np.frombuffer(data, np.uint8)
    # bmp格式数据转图片
    if len(np_data) % (width * height) == 0:
        img = np.reshape(np_data, (height, width, len(np_data) // (width * height)))
    else:
        # jpg或png格式转图片
        img = cv2.imdecode(np_data, cv2.IMREAD_ANYCOLOR)
    cv2.imshow('123',img)
    cv2.waitKey(0)

在查看官方源码过程中,感觉代码比较严谨,虽然没有过多的注释非常通俗易懂。看样子过段时间得再将《代码简洁之道》再好好看一遍

相关推荐

电脑桌面图标设置(电脑桌面图标设置自动排列)

电脑的桌面图标设置包括随意摆放图标,调整图标大小及排列顺序等,那么电脑桌面图标怎么设置呢?下面就以iOS13系统版本的iPhone8Plus手机为例来为你解答,一起来看看吧!首先使用鼠标右键单击电...

ps序列号是什么(ps序列号是什么开头的)

ps序列号是AdobePhotoshop软件为了防止盗版而采取的保护措施。序列号有时也指“机器码”,是有些软件为了防止盗版而采取的保护措施。但网络上往往会有注册机等类似软件用以免费获得许可。序列号就...

腾达路由器找不到wifi(腾达路由器找不到高级设置)

如果你的腾达路由器没有wifi信号,可能是未启用wifi功能,或者设置了隐藏wifi,当然也有可能是路由器的wifi功能坏掉了,可以先登录到它的设置页面,正确配置wifi。1.关闭了指示灯有些型号的...

win7如何分区电脑硬盘(win7怎么分硬盘)

在Win7中,你可以通过打开“计算机”窗口,右键点击你要分区的磁盘,然后选择“管理”选项。接着在弹出的“计算机管理”窗口中,找到“存储”下的“磁盘管理”选项,右键点击你要分区的磁盘,在弹出的菜单选择“...

电脑打不开文档和表格怎么办

原因是电脑软件问题。根据你的描述,电脑做了注册表清理,Word文档和Excel都打不开了。原因是:文件关联被删除了。解决方法是:1,打开Word软件,然后在里面选打开找到Word文档,确认就自动打开关...

路由器的作用与功能通俗(路由器的作用与功能通俗讲解)
路由器的作用与功能通俗(路由器的作用与功能通俗讲解)

路由器的功能如下:第一,网络互连:路由器支持各种局域网和广域网接口,主要用于互连局域网和广域网,实现不同网络互相通信。第二,数据处理:提供包括分组过滤、分组转发、优先级、复用、加密、压缩和防火墙等功能。第三,网络管理:路由器提供包括路由器配...

2026-01-05 17:55 liuian

如何安装双系统win10和linux

1.首先在“我的电脑”桌面,用电脑键盘win+R键,进入运行界面,在“运行”中输入msconfig,然后点击“确定”,进入系统引导盘中。2.然后进入系统配置的界面后,点击界面上方的引导选项,进入。3....

ios用什么下载bt或磁力(ios手机用什么下载bt)

ios好用的磁力链接软件是迅雷。苹果商店下架了,可通过电脑在手机安装PP助手,手机打开PP助手,找到该软件后,从简介里找到历史版本,就可把经典的5135版本(520版本可能会闪退)下载回手机里即可。在...

好看免费的壁纸软件(好看免费的壁纸软件下载)
  • 好看免费的壁纸软件(好看免费的壁纸软件下载)
  • 好看免费的壁纸软件(好看免费的壁纸软件下载)
  • 好看免费的壁纸软件(好看免费的壁纸软件下载)
  • 好看免费的壁纸软件(好看免费的壁纸软件下载)
windows+r没反应(windows+l没反应)

原因:1、可能是键盘是没电。按下键盘左侧的大小写切换键CapsLock键,观察键盘上的指示灯Caps灯是否点亮。如能点亮,说明键盘的硬件很有可能已经损坏。如果不能点亮,则检查键盘与电脑主机连接口是否接...

一个电脑装两个显卡会怎么样

同一台主机内安装两块显卡,有两种可能:两块一模一样的、两块不一样的。  两块不一样的对电脑没有任何性能提升,唯一起的作用就是备份和双屏。可以将两台显示器分别接在这两个显卡上实现双屏输出,或者其备份作用...

为什么u盘在电脑上读不出来(为什么u盘的内容在电脑上读不出来)

U盘在电脑上读不出来可能有多种原因。以下是一些常见的问题和解决方法:U盘连接问题:首先,请确保U盘已正确连接到电脑的USB接口。尝试将U盘插入其他USB接口,或者尝试使用不同的USB线缆进行连接。驱动...

ios最新系统是多少(ios文件怎么装系统)

1.iOS13。 2.苹果手机现在的最新版本是iPhone11系列,iPhone11系列将会用上解锁更快更安全的3D结构光人脸解锁方式,搭载基于7纳米...3.iPhone11延续上一代1...

vmware虚拟机安装win10系统(vmware虚拟机如何安装系统)

原因是Win10电脑配置是不符合运行Hyper-V虚拟机的要求(主要是CPU的虚拟化支持功能),解决办法1、进入bios设置,找到No-ExecuteMemoryProtection设置将其设...

笔记本xp系统重装系统教程(笔记本做xp系统)

重装XP系统的步骤如下:1.首先备份您的重要文件和数据。2.插入XP系统安装光盘,重新启动计算机。3.在启动时按下计算机制造商指定的键(通常是F2、F12、Esc等)进入BIOS设置或启动菜单。...