pdf_image_tools.py 1.2 KB

12345678910111213141516171819202122232425262728293031
  1. from magic_pdf.data.data_reader_writer import DataWriter
  2. from magic_pdf.libs.commons import fitz, join_path
  3. from magic_pdf.libs.hash_utils import compute_sha256
  4. def cut_image(bbox: tuple, page_num: int, page: fitz.Page, return_path, imageWriter: DataWriter):
  5. """从第page_num页的page中,根据bbox进行裁剪出一张jpg图片,返回图片路径 save_path:需要同时支持s3和本地,
  6. 图片存放在save_path下,文件名是:
  7. {page_num}_{bbox[0]}_{bbox[1]}_{bbox[2]}_{bbox[3]}.jpg , bbox内数字取整。"""
  8. # 拼接文件名
  9. filename = f'{page_num}_{int(bbox[0])}_{int(bbox[1])}_{int(bbox[2])}_{int(bbox[3])}'
  10. # 老版本返回不带bucket的路径
  11. img_path = join_path(return_path, filename) if return_path is not None else None
  12. # 新版本生成平铺路径
  13. img_hash256_path = f'{compute_sha256(img_path)}.jpg'
  14. # 将坐标转换为fitz.Rect对象
  15. rect = fitz.Rect(*bbox)
  16. # 配置缩放倍数为3倍
  17. zoom = fitz.Matrix(3, 3)
  18. # 截取图片
  19. pix = page.get_pixmap(clip=rect, matrix=zoom)
  20. byte_data = pix.tobytes(output='jpeg', jpg_quality=95)
  21. imageWriter.write(img_hash256_path, byte_data)
  22. return img_hash256_path