|
|
@@ -3,12 +3,6 @@ import sys
|
|
|
import time
|
|
|
from urllib.parse import quote
|
|
|
|
|
|
-from magic_pdf.dict2md.ocr_mkcontent import (
|
|
|
- ocr_mk_nlp_markdown,
|
|
|
- ocr_mk_mm_markdown,
|
|
|
- ocr_mk_mm_standard_format,
|
|
|
- ocr_mk_mm_markdown_with_para, ocr_mk_mm_markdown_with_para_and_pagination, ocr_mk_nlp_markdown_with_para,
|
|
|
-)
|
|
|
from magic_pdf.libs.commons import (
|
|
|
read_file,
|
|
|
join_path,
|
|
|
@@ -19,6 +13,7 @@ from magic_pdf.libs.commons import (
|
|
|
from magic_pdf.libs.drop_reason import DropReason
|
|
|
from magic_pdf.libs.json_compressor import JsonCompressor
|
|
|
from magic_pdf.dict2md.mkcontent import mk_nlp_markdown, mk_universal_format
|
|
|
+from magic_pdf.ocr_pipeline import ocr_dropped_parse_pdf
|
|
|
from magic_pdf.pdf_parse_by_model import parse_pdf_by_model
|
|
|
from magic_pdf.filter.pdf_classify_by_type import classify
|
|
|
from magic_pdf.filter.pdf_meta_scan import pdf_meta_scan
|
|
|
@@ -26,7 +21,6 @@ from loguru import logger
|
|
|
from magic_pdf.pdf_parse_for_train import parse_pdf_for_train
|
|
|
from magic_pdf.train_utils.convert_to_train_format import convert_to_train_format
|
|
|
from app.common.s3 import get_s3_config, get_s3_client
|
|
|
-from magic_pdf.pdf_parse_by_ocr import parse_pdf_by_ocr
|
|
|
|
|
|
|
|
|
def exception_handler(jso: dict, e):
|
|
|
@@ -400,222 +394,6 @@ def uni_parse_pdf(jso: dict, start_page_id=0, debug_mode=False) -> dict:
|
|
|
jso = ocr_dropped_parse_pdf(jso, start_page_id=start_page_id, debug_mode=debug_mode)
|
|
|
return jso
|
|
|
|
|
|
-
|
|
|
-# 专门用来跑被drop的pdf,跑完之后需要把need_drop字段置为false
|
|
|
-def ocr_dropped_parse_pdf(jso: dict, start_page_id=0, debug_mode=False) -> dict:
|
|
|
- if not jso.get("need_drop", False):
|
|
|
- return jso
|
|
|
- else:
|
|
|
- jso = ocr_parse_pdf_core(
|
|
|
- jso, start_page_id=start_page_id, debug_mode=debug_mode
|
|
|
- )
|
|
|
- jso["need_drop"] = False
|
|
|
- return jso
|
|
|
-
|
|
|
-
|
|
|
-def ocr_parse_pdf(jso: dict, start_page_id=0, debug_mode=False) -> dict:
|
|
|
- # 检测debug开关
|
|
|
- if debug_mode:
|
|
|
- pass
|
|
|
- else: # 如果debug没开,则检测是否有needdrop字段
|
|
|
- if jso.get("need_drop", False):
|
|
|
- return jso
|
|
|
-
|
|
|
- jso = ocr_parse_pdf_core(jso, start_page_id=start_page_id, debug_mode=debug_mode)
|
|
|
- return jso
|
|
|
-
|
|
|
-
|
|
|
-def ocr_parse_pdf_core(jso: dict, start_page_id=0, debug_mode=False) -> dict:
|
|
|
- s3_pdf_path = jso.get("file_location")
|
|
|
- s3_config = get_s3_config(s3_pdf_path)
|
|
|
- model_output_json_list = jso.get("doc_layout_result")
|
|
|
- data_source = get_data_source(jso)
|
|
|
- file_id = jso.get("file_id")
|
|
|
- book_name = f"{data_source}/{file_id}"
|
|
|
- try:
|
|
|
- save_path = s3_image_save_path
|
|
|
- image_s3_config = get_s3_config(save_path)
|
|
|
- start_time = time.time() # 记录开始时间
|
|
|
- # 先打印一下book_name和解析开始的时间
|
|
|
- logger.info(
|
|
|
- f"book_name is:{book_name},start_time is:{formatted_time(start_time)}",
|
|
|
- file=sys.stderr,
|
|
|
- )
|
|
|
- pdf_info_dict = parse_pdf_by_ocr(
|
|
|
- s3_pdf_path,
|
|
|
- s3_config,
|
|
|
- model_output_json_list,
|
|
|
- save_path,
|
|
|
- book_name,
|
|
|
- pdf_model_profile=None,
|
|
|
- image_s3_config=image_s3_config,
|
|
|
- start_page_id=start_page_id,
|
|
|
- debug_mode=debug_mode,
|
|
|
- )
|
|
|
- pdf_info_dict = JsonCompressor.compress_json(pdf_info_dict)
|
|
|
- jso["pdf_intermediate_dict"] = pdf_info_dict
|
|
|
- end_time = time.time() # 记录完成时间
|
|
|
- parse_time = int(end_time - start_time) # 计算执行时间
|
|
|
- # 解析完成后打印一下book_name和耗时
|
|
|
- logger.info(
|
|
|
- f"book_name is:{book_name},end_time is:{formatted_time(end_time)},cost_time is:{parse_time}",
|
|
|
- file=sys.stderr,
|
|
|
- )
|
|
|
- jso["parse_time"] = parse_time
|
|
|
- except Exception as e:
|
|
|
- jso = exception_handler(jso, e)
|
|
|
- return jso
|
|
|
-
|
|
|
-
|
|
|
-def ocr_pdf_intermediate_dict_to_markdown(jso: dict, debug_mode=False) -> dict:
|
|
|
-
|
|
|
- if debug_mode:
|
|
|
- pass
|
|
|
- else: # 如果debug没开,则检测是否有needdrop字段
|
|
|
- if jso.get("need_drop", False):
|
|
|
- book_name = join_path(get_data_source(jso), jso["file_id"])
|
|
|
- logger.info(f"book_name is:{book_name} need drop", file=sys.stderr)
|
|
|
- jso["dropped"] = True
|
|
|
- return jso
|
|
|
- try:
|
|
|
- pdf_intermediate_dict = jso["pdf_intermediate_dict"]
|
|
|
- # 将 pdf_intermediate_dict 解压
|
|
|
- pdf_intermediate_dict = JsonCompressor.decompress_json(pdf_intermediate_dict)
|
|
|
- markdown_content = ocr_mk_mm_markdown(pdf_intermediate_dict)
|
|
|
- jso["content"] = markdown_content
|
|
|
- logger.info(
|
|
|
- f"book_name is:{get_data_source(jso)}/{jso['file_id']},markdown content length is {len(markdown_content)}",
|
|
|
- file=sys.stderr,
|
|
|
- )
|
|
|
- # 把无用的信息清空
|
|
|
- jso["doc_layout_result"] = ""
|
|
|
- jso["pdf_intermediate_dict"] = ""
|
|
|
- jso["pdf_meta"] = ""
|
|
|
- except Exception as e:
|
|
|
- jso = exception_handler(jso, e)
|
|
|
- return jso
|
|
|
-
|
|
|
-
|
|
|
-def ocr_pdf_intermediate_dict_to_markdown_with_para(jso: dict, debug_mode=False) -> dict:
|
|
|
-
|
|
|
- if debug_mode:
|
|
|
- pass
|
|
|
- else: # 如果debug没开,则检测是否有needdrop字段
|
|
|
- if jso.get("need_drop", False):
|
|
|
- book_name = join_path(get_data_source(jso), jso["file_id"])
|
|
|
- logger.info(f"book_name is:{book_name} need drop", file=sys.stderr)
|
|
|
- jso["dropped"] = True
|
|
|
- return jso
|
|
|
- try:
|
|
|
- pdf_intermediate_dict = jso["pdf_intermediate_dict"]
|
|
|
- # 将 pdf_intermediate_dict 解压
|
|
|
- pdf_intermediate_dict = JsonCompressor.decompress_json(pdf_intermediate_dict)
|
|
|
- # markdown_content = ocr_mk_mm_markdown_with_para(pdf_intermediate_dict)
|
|
|
- markdown_content = ocr_mk_nlp_markdown_with_para(pdf_intermediate_dict)
|
|
|
- jso["content"] = markdown_content
|
|
|
- logger.info(
|
|
|
- f"book_name is:{get_data_source(jso)}/{jso['file_id']},markdown content length is {len(markdown_content)}",
|
|
|
- file=sys.stderr,
|
|
|
- )
|
|
|
- # 把无用的信息清空
|
|
|
- jso["doc_layout_result"] = ""
|
|
|
- jso["pdf_intermediate_dict"] = ""
|
|
|
- jso["pdf_meta"] = ""
|
|
|
- except Exception as e:
|
|
|
- jso = exception_handler(jso, e)
|
|
|
- return jso
|
|
|
-
|
|
|
-
|
|
|
-def ocr_pdf_intermediate_dict_to_markdown_with_para_and_pagination(jso: dict, debug_mode=False) -> dict:
|
|
|
-
|
|
|
- if debug_mode:
|
|
|
- pass
|
|
|
- else: # 如果debug没开,则检测是否有needdrop字段
|
|
|
- if jso.get("need_drop", False):
|
|
|
- book_name = join_path(get_data_source(jso), jso["file_id"])
|
|
|
- logger.info(f"book_name is:{book_name} need drop", file=sys.stderr)
|
|
|
- jso["dropped"] = True
|
|
|
- return jso
|
|
|
- try:
|
|
|
- pdf_intermediate_dict = jso["pdf_intermediate_dict"]
|
|
|
- # 将 pdf_intermediate_dict 解压
|
|
|
- pdf_intermediate_dict = JsonCompressor.decompress_json(pdf_intermediate_dict)
|
|
|
- markdown_content = ocr_mk_mm_markdown_with_para_and_pagination(pdf_intermediate_dict)
|
|
|
- jso["content"] = markdown_content
|
|
|
- logger.info(
|
|
|
- f"book_name is:{get_data_source(jso)}/{jso['file_id']},markdown content length is {len(markdown_content)}",
|
|
|
- file=sys.stderr,
|
|
|
- )
|
|
|
- # 把无用的信息清空
|
|
|
- # jso["doc_layout_result"] = ""
|
|
|
- jso["pdf_intermediate_dict"] = ""
|
|
|
- # jso["pdf_meta"] = ""
|
|
|
- except Exception as e:
|
|
|
- jso = exception_handler(jso, e)
|
|
|
- return jso
|
|
|
-
|
|
|
-
|
|
|
-def ocr_pdf_intermediate_dict_to_markdown_with_para_for_qa(
|
|
|
- jso: dict, debug_mode=False
|
|
|
-) -> dict:
|
|
|
-
|
|
|
- if debug_mode:
|
|
|
- pass
|
|
|
- else: # 如果debug没开,则检测是否有needdrop字段
|
|
|
- if jso.get("need_drop", False):
|
|
|
- book_name = join_path(get_data_source(jso), jso["file_id"])
|
|
|
- logger.info(f"book_name is:{book_name} need drop", file=sys.stderr)
|
|
|
- jso["dropped"] = True
|
|
|
- return jso
|
|
|
- try:
|
|
|
- pdf_intermediate_dict = jso["pdf_intermediate_dict"]
|
|
|
- # 将 pdf_intermediate_dict 解压
|
|
|
- pdf_intermediate_dict = JsonCompressor.decompress_json(pdf_intermediate_dict)
|
|
|
- markdown_content = ocr_mk_mm_markdown_with_para(pdf_intermediate_dict)
|
|
|
- jso["content_ocr"] = markdown_content
|
|
|
- logger.info(
|
|
|
- f"book_name is:{get_data_source(jso)}/{jso['file_id']},markdown content length is {len(markdown_content)}",
|
|
|
- file=sys.stderr,
|
|
|
- )
|
|
|
- # 把无用的信息清空
|
|
|
- jso["doc_layout_result"] = ""
|
|
|
- jso["pdf_intermediate_dict"] = ""
|
|
|
- jso["mid_json_ocr"] = pdf_intermediate_dict
|
|
|
- jso["pdf_meta"] = ""
|
|
|
- except Exception as e:
|
|
|
- jso = exception_handler(jso, e)
|
|
|
- return jso
|
|
|
-
|
|
|
-
|
|
|
-def ocr_pdf_intermediate_dict_to_standard_format(jso: dict, debug_mode=False) -> dict:
|
|
|
-
|
|
|
- if debug_mode:
|
|
|
- pass
|
|
|
- else: # 如果debug没开,则检测是否有needdrop字段
|
|
|
- if jso.get("need_drop", False):
|
|
|
- book_name = join_path(get_data_source(jso), jso["file_id"])
|
|
|
- logger.info(f"book_name is:{book_name} need drop", file=sys.stderr)
|
|
|
- jso["dropped"] = True
|
|
|
- return jso
|
|
|
- try:
|
|
|
- pdf_intermediate_dict = jso["pdf_intermediate_dict"]
|
|
|
- # 将 pdf_intermediate_dict 解压
|
|
|
- pdf_intermediate_dict = JsonCompressor.decompress_json(pdf_intermediate_dict)
|
|
|
- standard_format = ocr_mk_mm_standard_format(pdf_intermediate_dict)
|
|
|
- jso["content_list"] = standard_format
|
|
|
- logger.info(
|
|
|
- f"book_name is:{get_data_source(jso)}/{jso['file_id']},content_list length is {len(standard_format)}",
|
|
|
- file=sys.stderr,
|
|
|
- )
|
|
|
- # 把无用的信息清空
|
|
|
- jso["doc_layout_result"] = ""
|
|
|
- jso["pdf_intermediate_dict"] = ""
|
|
|
- jso["pdf_meta"] = ""
|
|
|
- except Exception as e:
|
|
|
- jso = exception_handler(jso, e)
|
|
|
- return jso
|
|
|
-
|
|
|
-
|
|
|
def parse_pdf_for_model_train(jso: dict, start_page_id=0, debug_mode=False) -> dict:
|
|
|
# 检测debug开关
|
|
|
if debug_mode:
|