common.py 4.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
9
10

import magic_pdf.model as model_config
from magic_pdf.libs.draw_bbox import (draw_layout_bbox, draw_span_bbox,
                                      drow_model_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
35
36
37
38
39
40
41
42
    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,
    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,
    f_dump_content_list=False,
    f_make_md_mode=MakeMode.MM_MD,
43
    f_draw_model_bbox=False,
icecraft's avatar
icecraft committed
44
45
):
    orig_model_list = copy.deepcopy(model_list)
46
47
    local_image_dir, local_md_dir = prepare_env(output_dir, pdf_file_name,
                                                parse_method)
48

49
50
    image_writer, md_writer = DiskReaderWriter(
        local_image_dir), DiskReaderWriter(local_md_dir)
icecraft's avatar
icecraft committed
51
52
    image_dir = str(os.path.basename(local_image_dir))

53
54
    if parse_method == 'auto':
        jso_useful_key = {'_pdf_type': '', 'model_list': model_list}
icecraft's avatar
icecraft committed
55
        pipe = UNIPipe(pdf_bytes, jso_useful_key, image_writer, is_debug=True)
56
    elif parse_method == 'txt':
icecraft's avatar
icecraft committed
57
        pipe = TXTPipe(pdf_bytes, model_list, image_writer, is_debug=True)
58
    elif parse_method == 'ocr':
icecraft's avatar
icecraft committed
59
60
        pipe = OCRPipe(pdf_bytes, model_list, image_writer, is_debug=True)
    else:
61
        logger.error('unknown parse method')
icecraft's avatar
icecraft committed
62
63
64
65
66
67
68
69
70
        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:
71
            logger.error('need model list input')
icecraft's avatar
icecraft committed
72
73
74
            exit(2)

    pipe.pipe_parse()
75
    pdf_info = pipe.pdf_mid_data['pdf_info']
icecraft's avatar
icecraft committed
76
    if f_draw_layout_bbox:
77
        draw_layout_bbox(pdf_info, pdf_bytes, local_md_dir, pdf_file_name)
icecraft's avatar
icecraft committed
78
    if f_draw_span_bbox:
79
        draw_span_bbox(pdf_info, pdf_bytes, local_md_dir, pdf_file_name)
80
    if f_draw_model_bbox:
81
82
        drow_model_bbox(orig_model_list, pdf_bytes, local_md_dir,
                        pdf_file_name)
icecraft's avatar
icecraft committed
83

84
85
86
    md_content = pipe.pipe_mk_markdown(image_dir,
                                       drop_mode=DropMode.NONE,
                                       md_make_mode=f_make_md_mode)
icecraft's avatar
icecraft committed
87
88
89
    if f_dump_md:
        md_writer.write(
            content=md_content,
90
            path=f'{pdf_file_name}.md',
icecraft's avatar
icecraft committed
91
92
93
94
95
            mode=AbsReaderWriter.MODE_TXT,
        )

    if f_dump_middle_json:
        md_writer.write(
96
97
98
99
            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
100
101
102
103
104
            mode=AbsReaderWriter.MODE_TXT,
        )

    if f_dump_model_json:
        md_writer.write(
105
106
107
108
            content=json_parse.dumps(orig_model_list,
                                     ensure_ascii=False,
                                     indent=4),
            path=f'{pdf_file_name}_model.json',
icecraft's avatar
icecraft committed
109
110
111
112
113
114
            mode=AbsReaderWriter.MODE_TXT,
        )

    if f_dump_orig_pdf:
        md_writer.write(
            content=pdf_bytes,
115
            path=f'{pdf_file_name}_origin.pdf',
icecraft's avatar
icecraft committed
116
117
118
119
120
121
            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(
122
123
124
125
            content=json_parse.dumps(content_list,
                                     ensure_ascii=False,
                                     indent=4),
            path=f'{pdf_file_name}_content_list.json',
icecraft's avatar
icecraft committed
126
127
128
            mode=AbsReaderWriter.MODE_TXT,
        )

129
    logger.info(f'local output dir is {local_md_dir}')
130

icecraft's avatar
icecraft committed
131

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