common.py 5.34 KB
Newer Older
icecraft's avatar
icecraft committed
1
import copy
2
3
4
import json as json_parse
import os

icecraft's avatar
icecraft committed
5
6
import click
from loguru import logger
7
8

import magic_pdf.model as model_config
9
10
from magic_pdf.libs.draw_bbox import (draw_layout_bbox, draw_line_sort_bbox,
                                      draw_model_bbox, draw_span_bbox)
icecraft's avatar
icecraft committed
11
12
13
from magic_pdf.libs.MakeContentConfig import DropMode, MakeMode
from magic_pdf.pipe.OCRPipe import OCRPipe
from magic_pdf.pipe.TXTPipe import TXTPipe
14
from magic_pdf.pipe.UNIPipe import UNIPipe
icecraft's avatar
icecraft committed
15
from magic_pdf.rw.AbsReaderWriter import AbsReaderWriter
16
from magic_pdf.rw.DiskReaderWriter import DiskReaderWriter
icecraft's avatar
icecraft committed
17
18
19
20
21


def prepare_env(output_dir, pdf_file_name, method):
    local_parent_dir = os.path.join(output_dir, pdf_file_name, method)

22
    local_image_dir = os.path.join(str(local_parent_dir), 'images')
icecraft's avatar
icecraft committed
23
24
25
26
27
28
29
30
31
32
33
34
    local_md_dir = local_parent_dir
    os.makedirs(local_image_dir, exist_ok=True)
    os.makedirs(local_md_dir, exist_ok=True)
    return local_image_dir, local_md_dir


def do_parse(
    output_dir,
    pdf_file_name,
    pdf_bytes,
    model_list,
    parse_method,
35
    debug_able,
icecraft's avatar
icecraft committed
36
37
38
39
40
41
    f_draw_span_bbox=True,
    f_draw_layout_bbox=True,
    f_dump_md=True,
    f_dump_middle_json=True,
    f_dump_model_json=True,
    f_dump_orig_pdf=True,
42
    f_dump_content_list=True,
icecraft's avatar
icecraft committed
43
    f_make_md_mode=MakeMode.MM_MD,
44
    f_draw_model_bbox=False,
45
    f_draw_line_sort_bbox=False,
46
47
    start_page_id=0,
    end_page_id=None,
48
    lang=None,
49
50
51
    layout_model=None,
    formula_enable=None,
    table_enable=None,
icecraft's avatar
icecraft committed
52
):
53
    if debug_able:
54
        logger.warning('debug mode is on')
55
        f_draw_model_bbox = True
56
        f_draw_line_sort_bbox = True
57

icecraft's avatar
icecraft committed
58
    orig_model_list = copy.deepcopy(model_list)
59
60
    local_image_dir, local_md_dir = prepare_env(output_dir, pdf_file_name,
                                                parse_method)
61

62
63
    image_writer, md_writer = DiskReaderWriter(
        local_image_dir), DiskReaderWriter(local_md_dir)
icecraft's avatar
icecraft committed
64
65
    image_dir = str(os.path.basename(local_image_dir))

66
67
    if parse_method == 'auto':
        jso_useful_key = {'_pdf_type': '', 'model_list': model_list}
68
        pipe = UNIPipe(pdf_bytes, jso_useful_key, image_writer, is_debug=True,
69
70
                       start_page_id=start_page_id, end_page_id=end_page_id, lang=lang,
                       layout_model=layout_model, formula_enable=formula_enable, table_enable=table_enable)
71
    elif parse_method == 'txt':
72
        pipe = TXTPipe(pdf_bytes, model_list, image_writer, is_debug=True,
73
74
                       start_page_id=start_page_id, end_page_id=end_page_id, lang=lang,
                       layout_model=layout_model, formula_enable=formula_enable, table_enable=table_enable)
75
    elif parse_method == 'ocr':
76
        pipe = OCRPipe(pdf_bytes, model_list, image_writer, is_debug=True,
77
78
                       start_page_id=start_page_id, end_page_id=end_page_id, lang=lang,
                       layout_model=layout_model, formula_enable=formula_enable, table_enable=table_enable)
icecraft's avatar
icecraft committed
79
    else:
80
        logger.error('unknown parse method')
icecraft's avatar
icecraft committed
81
82
83
84
85
86
87
88
89
        exit(1)

    pipe.pipe_classify()

    if len(model_list) == 0:
        if model_config.__use_inside_model__:
            pipe.pipe_analyze()
            orig_model_list = copy.deepcopy(pipe.model_list)
        else:
90
            logger.error('need model list input')
icecraft's avatar
icecraft committed
91
92
93
            exit(2)

    pipe.pipe_parse()
94
    pdf_info = pipe.pdf_mid_data['pdf_info']
icecraft's avatar
icecraft committed
95
    if f_draw_layout_bbox:
96
        draw_layout_bbox(pdf_info, pdf_bytes, local_md_dir, pdf_file_name)
icecraft's avatar
icecraft committed
97
    if f_draw_span_bbox:
98
        draw_span_bbox(pdf_info, pdf_bytes, local_md_dir, pdf_file_name)
99
    if f_draw_model_bbox:
100
        draw_model_bbox(copy.deepcopy(orig_model_list), pdf_bytes, local_md_dir, pdf_file_name)
101
102
    if f_draw_line_sort_bbox:
        draw_line_sort_bbox(pdf_info, pdf_bytes, local_md_dir, pdf_file_name)
103

104
105
106
    md_content = pipe.pipe_mk_markdown(image_dir,
                                       drop_mode=DropMode.NONE,
                                       md_make_mode=f_make_md_mode)
icecraft's avatar
icecraft committed
107
108
109
    if f_dump_md:
        md_writer.write(
            content=md_content,
110
            path=f'{pdf_file_name}.md',
icecraft's avatar
icecraft committed
111
112
113
114
115
            mode=AbsReaderWriter.MODE_TXT,
        )

    if f_dump_middle_json:
        md_writer.write(
116
117
118
119
            content=json_parse.dumps(pipe.pdf_mid_data,
                                     ensure_ascii=False,
                                     indent=4),
            path=f'{pdf_file_name}_middle.json',
icecraft's avatar
icecraft committed
120
121
122
123
124
            mode=AbsReaderWriter.MODE_TXT,
        )

    if f_dump_model_json:
        md_writer.write(
125
126
127
128
            content=json_parse.dumps(orig_model_list,
                                     ensure_ascii=False,
                                     indent=4),
            path=f'{pdf_file_name}_model.json',
icecraft's avatar
icecraft committed
129
130
131
132
133
134
            mode=AbsReaderWriter.MODE_TXT,
        )

    if f_dump_orig_pdf:
        md_writer.write(
            content=pdf_bytes,
135
            path=f'{pdf_file_name}_origin.pdf',
icecraft's avatar
icecraft committed
136
137
138
139
140
141
            mode=AbsReaderWriter.MODE_BIN,
        )

    content_list = pipe.pipe_mk_uni_format(image_dir, drop_mode=DropMode.NONE)
    if f_dump_content_list:
        md_writer.write(
142
143
144
145
            content=json_parse.dumps(content_list,
                                     ensure_ascii=False,
                                     indent=4),
            path=f'{pdf_file_name}_content_list.json',
icecraft's avatar
icecraft committed
146
147
148
            mode=AbsReaderWriter.MODE_TXT,
        )

149
    logger.info(f'local output dir is {local_md_dir}')
150

icecraft's avatar
icecraft committed
151

152
parse_pdf_methods = click.Choice(['ocr', 'txt', 'auto'])