ocr_demo.py 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. import json
  2. import os
  3. from loguru import logger
  4. from pathlib import Path
  5. from app.common.s3 import get_s3_config
  6. from demo.demo_test import get_json_from_local_or_s3
  7. from magic_pdf.dict2md.ocr_mkcontent import (
  8. ocr_mk_mm_markdown_with_para,
  9. ocr_mk_nlp_markdown,
  10. ocr_mk_mm_markdown,
  11. ocr_mk_mm_standard_format,
  12. ocr_mk_mm_markdown_with_para_and_pagination
  13. )
  14. from magic_pdf.libs.commons import join_path
  15. from magic_pdf.pdf_parse_by_ocr import parse_pdf_by_ocr
  16. def save_markdown(markdown_text, input_filepath):
  17. # 获取输入文件的目录
  18. directory = os.path.dirname(input_filepath)
  19. # 获取输入文件的文件名(不带扩展名)
  20. base_name = os.path.basename(input_filepath)
  21. file_name_without_ext = os.path.splitext(base_name)[0]
  22. # 定义输出文件的路径
  23. output_filepath = os.path.join(directory, f"{file_name_without_ext}.md")
  24. # 将Markdown文本写入.md文件
  25. with open(output_filepath, 'w', encoding='utf-8') as file:
  26. file.write(markdown_text)
  27. def read_json_file(file_path):
  28. with open(file_path, 'r') as f:
  29. data = json.load(f)
  30. return data
  31. def ocr_local_parse(ocr_pdf_path, ocr_json_file_path):
  32. try:
  33. ocr_pdf_model_info = read_json_file(ocr_json_file_path)
  34. pth = Path(ocr_json_file_path)
  35. book_name = pth.name
  36. ocr_parse_core(book_name, ocr_pdf_path, ocr_pdf_model_info)
  37. except Exception as e:
  38. logger.exception(e)
  39. def ocr_online_parse(book_name, start_page_id=0, debug_mode=True):
  40. try:
  41. json_object = get_json_from_local_or_s3(book_name)
  42. # logger.info(json_object)
  43. s3_pdf_path = json_object["file_location"]
  44. s3_config = get_s3_config(s3_pdf_path)
  45. ocr_pdf_model_info = json_object.get("doc_layout_result")
  46. ocr_parse_core(book_name, s3_pdf_path, ocr_pdf_model_info, s3_config=s3_config)
  47. except Exception as e:
  48. logger.exception(e)
  49. def ocr_parse_core(book_name, ocr_pdf_path, ocr_pdf_model_info, start_page_id=0, s3_config=None):
  50. save_tmp_path = os.path.join(os.path.dirname(__file__), "../..", "tmp", "unittest")
  51. save_path = join_path(save_tmp_path, "md")
  52. save_path_with_bookname = os.path.join(save_path, book_name)
  53. text_content_save_path = f"{save_path_with_bookname}/book.md"
  54. pdf_info_dict = parse_pdf_by_ocr(
  55. ocr_pdf_path,
  56. s3_config,
  57. ocr_pdf_model_info,
  58. save_path,
  59. book_name,
  60. debug_mode=True)
  61. parent_dir = os.path.dirname(text_content_save_path)
  62. if not os.path.exists(parent_dir):
  63. os.makedirs(parent_dir)
  64. # markdown_content = mk_nlp_markdown(pdf_info_dict)
  65. markdown_content = ocr_mk_mm_markdown_with_para(pdf_info_dict)
  66. # markdown_pagination = ocr_mk_mm_markdown_with_para_and_pagination(pdf_info_dict)
  67. with open(text_content_save_path, "w", encoding="utf-8") as f:
  68. f.write(markdown_content)
  69. standard_format = ocr_mk_mm_standard_format(pdf_info_dict)
  70. standard_format_save_path = f"{save_path_with_bookname}/standard_format.txt"
  71. with open(standard_format_save_path, "w", encoding="utf-8") as f:
  72. f.write(str(standard_format))
  73. if __name__ == '__main__':
  74. pdf_path = r"/home/cxu/workspace/Magic-PDF/ocr_demo/j.1540-627x.2006.00176.x.pdf"
  75. json_file_path = r"/home/cxu/workspace/Magic-PDF/ocr_demo/j.1540-627x.2006.00176.x.json"
  76. ocr_local_parse(pdf_path, json_file_path)
  77. # book_name = "数学新星网/edu_00001236"
  78. # ocr_online_parse(book_name)
  79. pass