Skip to content

CosmosShadow/gptpdf

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gptpdf

CN doc EN doc

Using VLLM (like GPT-4o) to parse PDF into markdown.

Our method can almost perfectly parse typesetting, mathematical formulas, tables, pictures, charts, etc.

Average price per page: $0.013

This package use GeneralAgent lib to interact with OpenAI API.

Process steps

  1. Use the PyMuPDF library to parse the PDF and extract all non-text rectangular areas.
  2. Convert all non-text rectangular areas on the PDF into pictures and number them
  3. Mark each page of the PDF with a red rectangle and number and save it as an image, similar to the following:

  1. Based on the picture in step 3, use a large visual model (such as GPT-4o) to parse and get the markdown content.

DEMO

See examples/attention_is_all_you_need/output.md for PDF examples/attention_is_all_you_need.pdf.

Installation

pip install gptpdf

Usage

from gptpdf import parse_pdf
api_key = 'Your OpenAI API Key'
content, image_paths = parse_pdf(pdf_path, api_key=api_key)
print(content)

See more in test/test.py

API

parse_pdf(pdf_path, output_dir='./', api_key=None, base_url=None, model='gpt-4o', verbose=False)

parse pdf file to markdown file, and return markdown content and all image paths.

pdf_path: pdf file path

output_dir: output directory. store all images and markdown file

api_key: OpenAI API Key (optional). If not provided, Use OPENAI_API_KEY environment variable.

base_url: OpenAI Base URL. (optional). If not provided, Use OPENAI_BASE_URL environment variable.

model: OpenAI Vison LLM Model, default is 'gpt-4o'. You also can use qwen-vl-max

verbose: verbose mode

About

Using GPT to parse PDF

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages