Skip to content

Commit

Permalink
refactor: 逐页加载pdf, 图片类型单独保存成文件加载
Browse files Browse the repository at this point in the history
  • Loading branch information
liuruibin committed Aug 16, 2024
1 parent 0d59ab2 commit 0d0c8b8
Showing 1 changed file with 28 additions and 26 deletions.
54 changes: 28 additions & 26 deletions apps/common/handle/impl/pdf_split_handle.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,16 @@
import re
from typing import List

import pypdf
from pypdf import PdfReader, PdfWriter
import os
import tempfile
from langchain_community.document_loaders import PyPDFLoader

from common.handle.base_split_handle import BaseSplitHandle
from common.util.split_model import SplitModel

import time

default_pattern_list = [re.compile('(?<=^)# .*|(?<=\\n)# .*'),
re.compile('(?<=\\n)(?<!#)## (?!#).*|(?<=^)(?<!#)## (?!#).*'),
re.compile("(?<=\\n)(?<!#)### (?!#).*|(?<=^)(?<!#)### (?!#).*"),
Expand All @@ -26,26 +28,6 @@
re.compile("(?<!\n)\n\n+")]


def check_pdf_is_image(pdf_path):
try:
# 打开PDF文件
with open(pdf_path, "rb") as f:
reader = pypdf.PdfReader(f)
for page_num in range(len(reader.pages)):
page = reader.pages[page_num]

# 尝试提取文本
text = page.extract_text()
if text and text.strip(): # 如果页面中有文本内容
return False # 不是纯图片
else:
return True # 可能是图片或扫描件

except Exception as e:
print(f"Error: {e}")
return None


class PdfSplitHandle(BaseSplitHandle):
def handle(self, file, pattern_list: List, with_filter: bool, limit: int, get_buffer, save_image):
with tempfile.NamedTemporaryFile(delete=False) as temp_file:
Expand All @@ -56,17 +38,37 @@ def handle(self, file, pattern_list: List, with_filter: bool, limit: int, get_bu
temp_file_path = temp_file.name

try:
if check_pdf_is_image(temp_file_path):
loader = PyPDFLoader(temp_file_path, extract_images=True)
else:
loader = PyPDFLoader(temp_file_path, extract_images=False)
content = ""
reader = PdfReader(temp_file_path)
for page_num in range(len(reader.pages)):
start_time = time.time()
page = reader.pages[page_num]
text = page.extract_text()

if text and text.strip(): # 如果页面中有文本内容
page_content = text
else:
try:
writer = PdfWriter()
writer.add_page(page)
with tempfile.NamedTemporaryFile(delete=False) as output_pdf:
writer.write(output_pdf)
loader = PyPDFLoader(output_pdf.name, extract_images=True)
page_content = "\n" + loader.load()[0].page_content
finally:
os.remove(output_pdf.name)

content += page_content

content = "\n".join([page.page_content for page in loader.lazy_load()])
elapsed_time = time.time() - start_time
print(f"Time : {elapsed_time: .3f}s, Page: {page_num + 1}, content-length: {len(page_content)}")

if pattern_list is not None and len(pattern_list) > 0:
split_model = SplitModel(pattern_list, with_filter, limit)
else:
split_model = SplitModel(default_pattern_list, with_filter=with_filter, limit=limit)


except BaseException as e:
return {'name': file.name,
'content': []}
Expand Down

0 comments on commit 0d0c8b8

Please sign in to comment.