• PDF提取图片(错误纠正)


    有个任务需要抽取pdf中的图片,于是找了一个例子但是有错误,仅此记录下

    错误1、 AttributeError: 'Document' object has no attribute 'getObjectString

        解决方法:getObjectString  改成  _getXrefLength

    错误2、无法运行下面的程序(运行没有抽取图片)

        解决方法:如果你的pdf仅仅只是由图片组成可能不会抽取到图片,我查看了打印的信息

             发现没有object这个属性,但是可以看出这是一个图片的,所以只要修改部分代码就可以

              

    if not isXObject or not isImage: 
    修改为
    if  not isImage: 
    或者修改为
    if isImage==None

         

              

    环境:>=py3.5,代码如下:

    import fitz
    import time
    import re
    import os
    def pdf2pic(path, pic_path):
        t0 = time.clock()                          # 生成图片初始时间
        checkXO = r"/Type(?= */XObject)"           # 使用正则表达式来查找图片
        checkIM = r"/Subtype(?= */Image)"
        doc = fitz.open(path)                      # 打开pdf文件
        imgcount = 0                               # 图片计数
        lenXREF = doc._getXrefLength()             # 获取对象数量长度
         
        # 打印PDF的信息
        print("文件名:{}, 页数: {}, 对象: {}".format(path, len(doc), lenXREF - 1))
         
        # 遍历每一个对象
        for i in range(1, lenXREF):
            text = doc._getXrefString(i)            # 定义对象字符串
            isXObject = re.search(checkXO, text)    # 使用正则表达式查看是否是对象
            isImage = re.search(checkIM, text)      # 使用正则表达式查看是否是图片
            if not isXObject or not isImage:        # 如果不是对象也不是图片,则continue
                continue
            imgcount += 1
            pix = fitz.Pixmap(doc, i)               # 生成图像对象
            new_name = "图片{}.png".format(imgcount) # 生成图片的名称
            if pix.n < 5:                           # 如果pix.n<5,可以直接存为PNG
                pix.writePNG(os.path.join(pic_path, new_name))
            else:                                   # 否则先转换CMYK
                pix0 = fitz.Pixmap(fitz.csRGB, pix)
                pix0.writePNG(os.path.join(pic_path, new_name))
                pix0 = None
            pix = None                              # 释放资源
            t1 = time.clock()                       # 图片完成时间
            print("运行时间:{}s".format(t1 - t0))
            print("提取了{}张图片".format(imgcount))
             
    if __name__=='__main__':
        path = r"C:UserslenovoDesktop数据.pdf"
        pic_path = r'C:UserslenovoDesktop图片'
        # 创建保存图片的文件夹
        if os.path.exists(pic_path):
            print("文件夹已存在,不必重新创建!")
            pass
        else:
            os.mkdir(pic_path)
        pdf2pic(path, pic_path)

    参考:https://blog.csdn.net/qq_15969343/article/details/81673302

  • 相关阅读:
    jmeter巧用自增长型变量
    jmeter实现一次登录,多次业务请求(不同线程组间共享cookie和变量)
    jmeter实现IP欺骗
    基于jmeter+ant实现的接口自动化测试
    基于Robot Framework的接口自动化测试
    至少与至少
    code+7正式赛划水记+HardA~C题解
    code+7彩蛋题题解
    开发一个博客园系统
    beautifulSoup模块
  • 原文地址:https://www.cnblogs.com/51python/p/11265496.html
Copyright © 2020-2023  润新知