Skip to main content

Extract structured information from images, tables, and text in PDF document.

Project description

pdf-decomposer

For the convenience of analysis, sometimes it is necessary to extract the content from PDF document. This project uses local tools to extract images, tables, and text from PDF file.

Install

Install appropriate version of PaddlePaddle and PyTorch. Here is an example using CUDA 11.8.

sudo apt install tesseract-ocr
sudo apt install tesseract-ocr-chi-sim

pip install paddlepaddle-gpu==2.5.2 -i https://pypi.tuna.tsinghua.edu.cn/simple
pip install torch torchvision torchaudio -i https://download.pytorch.org/whl/cu118
pip install 'git+https://github.com/facebookresearch/detectron2.git'

Install from source code.

pip install .

or

pip install pdf-decomposer

If you are unable to download the layout-parser model automatically, please download it yourself based on the link provided in the error message, and then specify the local config_path and model_path.

Solution based on PaddleOCR

Use layout analysis and table structure model in PaddleOCR ppstructure to recognize layout elements and reconstruct tables. Then use PyMuPDF to parse text and organize paragraph.

import pdf_decomposer

decomposer = pdf_decomposer.PaddlePDFDecomposer()
decomposer(example_file, output_dir)

Alternative local solution

Compared to the Paddle solution, use layout-parser to conduct layout analysis, and then search adaptive thresholds with genetic algorithm to reconstruct tables.

import pdf_decomposer

decomposer = pdf_decomposer.OpenPDFDecomposer()
decomposer(example_file, output_dir)

Solution based on Adobe service

Call Acrobat PDF Services API to extract various elements from PDF files. Please apply for the API key here. Make sure to set api key before running.

export ADOBE_CLIENT_ID=<YOUR CLIENT ID>
export ADOBE_CLIENT_SECRET=<YOUR CLIENT SECRET>
import pdf_decomposer

decomposer = pdf_decomposer.AdobePDFDecomposer()
decomposer(example_file, output_dir)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pdf_decomposer-0.2.1.tar.gz (22.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pdf_decomposer-0.2.1-py2.py3-none-any.whl (24.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pdf_decomposer-0.2.1.tar.gz.

File metadata

  • Download URL: pdf_decomposer-0.2.1.tar.gz
  • Upload date:
  • Size: 22.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for pdf_decomposer-0.2.1.tar.gz
Algorithm Hash digest
SHA256 4a707cf8c0a360cf066915de8a682ba3f0803b7a86b4bc9f4dd8dc03f34debcd
MD5 cc1c4293d0980009c766edadea5c4113
BLAKE2b-256 49d5a28f579275d287d7fda388f5fec3a7a6a4c0a3220fe4f686c6c22a840c96

See more details on using hashes here.

File details

Details for the file pdf_decomposer-0.2.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pdf_decomposer-0.2.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a2f368d25577aa219c841545e3cf633ac418b23e6a75d983cdbf653d0de4f89f
MD5 b9e529010d9daaff324deb41e0747065
BLAKE2b-256 98e06a3998f0e4e9bcf88e4b0ec0967c6b762d1498fa00dd836c9109159c8839

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page