51 lines
1.7 KiB
Python
51 lines
1.7 KiB
Python
|
|
# coding=utf-8
|
|||
|
|
"""
|
|||
|
|
@project: maxkb
|
|||
|
|
@Author:虎
|
|||
|
|
@file: text_split_handle.py
|
|||
|
|
@date:2024/3/27 18:19
|
|||
|
|
@desc:
|
|||
|
|
"""
|
|||
|
|
import re
|
|||
|
|
from typing import List
|
|||
|
|
|
|||
|
|
import fitz
|
|||
|
|
|
|||
|
|
from common.handle.base_split_handle import BaseSplitHandle
|
|||
|
|
from common.util.split_model import SplitModel
|
|||
|
|
|
|||
|
|
default_pattern_list = [re.compile('(?<=^)# .*|(?<=\\n)# .*'), re.compile('(?<!#)## (?!#).*'),
|
|||
|
|
re.compile("(?<!#)### (?!#).*"),
|
|||
|
|
re.compile("(?<!#)#### (?!#).*"), re.compile("(?<!#)##### (?!#).*"),
|
|||
|
|
re.compile("(?<!#)###### (?!#).*"), re.compile("(?<!\n)\n\n+")]
|
|||
|
|
|
|||
|
|
|
|||
|
|
def number_to_text(pdf_document, page_number):
|
|||
|
|
page = pdf_document.load_page(page_number)
|
|||
|
|
text = page.get_text()
|
|||
|
|
return text
|
|||
|
|
|
|||
|
|
|
|||
|
|
class PdfSplitHandle(BaseSplitHandle):
|
|||
|
|
def handle(self, file, pattern_list: List, with_filter: bool, limit: int, get_buffer):
|
|||
|
|
try:
|
|||
|
|
buffer = get_buffer(file)
|
|||
|
|
pdf_document = fitz.open(file.name, buffer)
|
|||
|
|
content = "\n".join([number_to_text(pdf_document, page_number) for page_number in range(len(pdf_document))])
|
|||
|
|
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': []}
|
|||
|
|
return {'name': file.name,
|
|||
|
|
'content': split_model.parse(content)
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
def support(self, file, get_buffer):
|
|||
|
|
file_name: str = file.name.lower()
|
|||
|
|
if file_name.endswith(".pdf"):
|
|||
|
|
return True
|
|||
|
|
return False
|