百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

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

ztj100 2024-11-08 15:07 45 浏览 0 评论

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

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)

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

相关推荐

再说圆的面积-蒙特卡洛(蒙特卡洛方法求圆周率的matlab程序)

在微积分-圆的面积和周长(1)介绍微积分方法求解圆的面积,本文使用蒙特卡洛方法求解圆面积。...

python编程:如何使用python代码绘制出哪些常见的机器学习图像?

专栏推荐...

python创建分类器小结(pytorch分类数据集创建)

简介:分类是指利用数据的特性将其分成若干类型的过程。监督学习分类器就是用带标记的训练数据建立一个模型,然后对未知数据进行分类。...

matplotlib——绘制散点图(matplotlib散点图颜色和图例)

绘制散点图不同条件(维度)之间的内在关联关系观察数据的离散聚合程度...

python实现实时绘制数据(python如何绘制)

方法一importmatplotlib.pyplotaspltimportnumpyasnpimporttimefrommathimport*plt.ion()#...

简单学Python——matplotlib库3——绘制散点图

前面我们学习了用matplotlib绘制折线图,今天我们学习绘制散点图。其实简单的散点图与折线图的语法基本相同,只是作图函数由plot()变成了scatter()。下面就绘制一个散点图:import...

数据分析-相关性分析可视化(相关性分析数据处理)

前面介绍了相关性分析的原理、流程和常用的皮尔逊相关系数和斯皮尔曼相关系数,具体可以参考...

免费Python机器学习课程一:线性回归算法

学习线性回归的概念并从头开始在python中开发完整的线性回归算法最基本的机器学习算法必须是具有单个变量的线性回归算法。如今,可用的高级机器学习算法,库和技术如此之多,以至于线性回归似乎并不重要。但是...

用Python进行机器学习(2)之逻辑回归

前面介绍了线性回归,本次介绍的是逻辑回归。逻辑回归虽然名字里面带有“回归”两个字,但是它是一种分类算法,通常用于解决二分类问题,比如某个邮件是否是广告邮件,比如某个评价是否为正向的评价。逻辑回归也可以...

【Python机器学习系列】拟合和回归傻傻分不清?一文带你彻底搞懂

一、拟合和回归的区别拟合...

推荐2个十分好用的pandas数据探索分析神器

作者:俊欣来源:关于数据分析与可视化...

向量数据库:解锁大模型记忆的关键!选型指南+实战案例全解析

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...

用Python进行机器学习(11)-主成分分析PCA

我们在机器学习中有时候需要处理很多个参数,但是这些参数有时候彼此之间是有着各种关系的,这个时候我们就会想:是否可以找到一种方式来降低参数的个数呢?这就是今天我们要介绍的主成分分析,英文是Princip...

神经网络基础深度解析:从感知机到反向传播

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...

Python实现基于机器学习的RFM模型

CDA数据分析师出品作者:CDALevelⅠ持证人岗位:数据分析师行业:大数据...

取消回复欢迎 发表评论: