cut_image.py 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. from loguru import logger
  2. from magic_pdf.config.ocr_content_type import ContentType
  3. from magic_pdf.libs.commons import join_path
  4. from magic_pdf.libs.pdf_image_tools import cut_image
  5. def ocr_cut_image_and_table(spans, page, page_id, pdf_bytes_md5, imageWriter):
  6. def return_path(type):
  7. return join_path(pdf_bytes_md5, type)
  8. for span in spans:
  9. span_type = span['type']
  10. if span_type == ContentType.Image:
  11. if not check_img_bbox(span['bbox']):
  12. continue
  13. span['image_path'] = cut_image(span['bbox'], page_id, page, return_path=return_path('images'),
  14. imageWriter=imageWriter)
  15. elif span_type == ContentType.Table:
  16. if not check_img_bbox(span['bbox']):
  17. continue
  18. span['image_path'] = cut_image(span['bbox'], page_id, page, return_path=return_path('tables'),
  19. imageWriter=imageWriter)
  20. return spans
  21. def txt_save_images_by_bboxes(page_num: int, page, pdf_bytes_md5: str,
  22. image_bboxes: list, images_overlap_backup: list, table_bboxes: list,
  23. equation_inline_bboxes: list,
  24. equation_interline_bboxes: list, imageWriter) -> dict:
  25. """返回一个dict, key为bbox, 值是图片地址."""
  26. image_info = []
  27. image_backup_info = []
  28. table_info = []
  29. inline_eq_info = []
  30. interline_eq_info = []
  31. # 图片的保存路径组成是这样的: {s3_or_local_path}/{book_name}/{images|tables|equations}/{page_num}_{bbox[0]}_{bbox[1]}_{bbox[2]}_{bbox[3]}.jpg
  32. def return_path(type):
  33. return join_path(pdf_bytes_md5, type)
  34. for bbox in image_bboxes:
  35. if not check_img_bbox(bbox):
  36. continue
  37. image_path = cut_image(bbox, page_num, page, return_path('images'), imageWriter)
  38. image_info.append({'bbox': bbox, 'image_path': image_path})
  39. for bbox in images_overlap_backup:
  40. if not check_img_bbox(bbox):
  41. continue
  42. image_path = cut_image(bbox, page_num, page, return_path('images'), imageWriter)
  43. image_backup_info.append({'bbox': bbox, 'image_path': image_path})
  44. for bbox in table_bboxes:
  45. if not check_img_bbox(bbox):
  46. continue
  47. image_path = cut_image(bbox, page_num, page, return_path('tables'), imageWriter)
  48. table_info.append({'bbox': bbox, 'image_path': image_path})
  49. return image_info, image_backup_info, table_info, inline_eq_info, interline_eq_info
  50. def check_img_bbox(bbox) -> bool:
  51. if any([bbox[0] >= bbox[2], bbox[1] >= bbox[3]]):
  52. logger.warning(f'image_bboxes: 错误的box, {bbox}')
  53. return False
  54. return True