pdf图片识别分类

解析pdf数据

试了几种方法
fitz-get_image后面方法不适用,用pixmap分辨率低
用pypdf2版本低方法用不了
用pdf2image还要下依赖工具
用spire.pdf的SaveAsImage分辨率低,ExtractImages可以但运行慢
先用spire.pdf的ExtractImages吧

from spire.pdf.common import ImageFormat
from spire.pdf import PdfDocument

# 从PDF文档提取图片,PDF文档的路径,存放图片的文件夹路径
def extract_images_from_pdf(file_path, output_folder):
    # 创建PdfDocument类的实例
    doc = PdfDocument()
    # 加载PDF文档
    doc.LoadFromFile(file_path)
    # 创建list来存储提取的图片
    images = []
    # 遍历文档的页面
    for i in range(doc.Pages.Count):
        # 获取当前页
        page = doc.Pages.get_Item(i)
        # 从页面提取图片并存储到list
        for img in page.ExtractImages():
            # print(img)
            images.append(img)
    # 将图片保存到指定文件夹
    for i, image in enumerate(images):
        image.Save(f"{output_folder}Image-{i+1}.jpg", ImageFormat.get_Jpeg())
    doc.Close()

# 调用函数实现从PDF提取图片
file_path = "副本.pdf"
output_folder = "tup/"
extract_images_from_pdf(file_path, output_folder)

ocr识别

试验几种方法paddleocr umiocr cnocr 微信截图等
识别效果都差不多 最先进的也就这样了,就用cnocr 运行效率高 其他更慢
调了调一些参数,发现不调还好一些
cnocr也和opencv一样不支持中文路径,直接用PIL读取传对象给cnocr就可以

from cnocr import CnOcr # 识别
from PIL import Image
def ocr_cn(path): # 输入图片path
    img=Image.open(path)
    # print(img)
    r = ocr.ocr(img)
    t = []  # 文本
    for each in r:
        # print(each['text'])
        t.append(each['text'])
    # print(t)
    return t

分类方法

分类方法有基于规则、基于词频统计、nlp算法-朴素贝叶斯 textcnn什么的
一般数据量小就规则,一般数据量大也先用规则看看 一些能看到的共性可以直接提出来,剩下的再用AI学习


分类完提示

用Tkinter或pyqt做窗口提示和交互

## 分类完提示
import tkinter as tk
from tkinter import messagebox
root = tk.Tk()
root.withdraw()
messagebox.showinfo("提示", "程序运行完成!")
messagebox.showinfo("提示", "分类完成!"+'\n'+'分类成功 条'+'\n'+'分类失败 条')

最近更新

  1. TCP协议是安全的吗?

    2024-04-06 10:28:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-06 10:28:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-06 10:28:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-06 10:28:03       20 阅读

热门阅读

  1. 算法——最小生成树

    2024-04-06 10:28:03       11 阅读
  2. 设计循环队列

    2024-04-06 10:28:03       12 阅读
  3. Spark, Storm, Flink简介

    2024-04-06 10:28:03       17 阅读
  4. SGM2048

    2024-04-06 10:28:03       16 阅读
  5. ARM Cordio WSF(二)——API接口

    2024-04-06 10:28:03       17 阅读
  6. 类全局变量与类单例模式优缺点比较

    2024-04-06 10:28:03       18 阅读
  7. XSS分类

    2024-04-06 10:28:03       17 阅读
  8. 【Node.js】ioredis

    2024-04-06 10:28:03       17 阅读
  9. python实现UDP客户端

    2024-04-06 10:28:03       15 阅读
  10. PyTorch中view()函数用法说明

    2024-04-06 10:28:03       21 阅读
  11. 【科普】卫星如何定位汽车

    2024-04-06 10:28:03       18 阅读
  12. Go语言创建HTTP服务器

    2024-04-06 10:28:03       17 阅读
  13. [Flutter]导入singular_flutter_sdk后运行到Android报错

    2024-04-06 10:28:03       19 阅读
  14. 大模型推理--KV cache解读

    2024-04-06 10:28:03       19 阅读