| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- from loguru import logger
- from magic_pdf.libs.commons import join_path
- from magic_pdf.libs.ocr_content_type import ContentType
- from magic_pdf.libs.pdf_image_tools import cut_image
- def ocr_cut_image_and_table(spans, page, page_id, pdf_bytes_md5, imageWriter):
- def return_path(type):
- return join_path(pdf_bytes_md5, type)
- for span in spans:
- span_type = span['type']
- if span_type == ContentType.Image:
- if not check_img_bbox(span['bbox']):
- continue
- span['image_path'] = cut_image(span['bbox'], page_id, page, return_path=return_path('images'),
- imageWriter=imageWriter)
- elif span_type == ContentType.Table:
- if not check_img_bbox(span['bbox']):
- continue
- span['image_path'] = cut_image(span['bbox'], page_id, page, return_path=return_path('tables'),
- imageWriter=imageWriter)
- return spans
- def txt_save_images_by_bboxes(page_num: int, page, pdf_bytes_md5: str,
- image_bboxes: list, images_overlap_backup: list, table_bboxes: list,
- equation_inline_bboxes: list,
- equation_interline_bboxes: list, imageWriter) -> dict:
- """
- 返回一个dict, key为bbox, 值是图片地址
- """
- image_info = []
- image_backup_info = []
- table_info = []
- inline_eq_info = []
- interline_eq_info = []
- # 图片的保存路径组成是这样的: {s3_or_local_path}/{book_name}/{images|tables|equations}/{page_num}_{bbox[0]}_{bbox[1]}_{bbox[2]}_{bbox[3]}.jpg
- def return_path(type):
- return join_path(pdf_bytes_md5, type)
- for bbox in image_bboxes:
- if not check_img_bbox(bbox):
- continue
- image_path = cut_image(bbox, page_num, page, return_path("images"), imageWriter)
- image_info.append({"bbox": bbox, "image_path": image_path})
- for bbox in images_overlap_backup:
- if not check_img_bbox(bbox):
- continue
- image_path = cut_image(bbox, page_num, page, return_path("images"), imageWriter)
- image_backup_info.append({"bbox": bbox, "image_path": image_path})
- for bbox in table_bboxes:
- if not check_img_bbox(bbox):
- continue
- image_path = cut_image(bbox, page_num, page, return_path("tables"), imageWriter)
- table_info.append({"bbox": bbox, "image_path": image_path})
- return image_info, image_backup_info, table_info, inline_eq_info, interline_eq_info
- def check_img_bbox(bbox) -> bool:
- if any([bbox[0] >= bbox[2], bbox[1] >= bbox[3]]):
- logger.warning(f"image_bboxes: 错误的box, {bbox}")
- return False
- return True
|