PDF Table Extraction for Humans.
Project description
Camelot: PDF Table Extraction for Humans
Camelot is a Python library that can help you extract tables from PDFs.
Features
- 📊 Five parsers —
lattice(ruled tables),stream(whitespace), the text-alignmentnetwork/hybrid, and the optional neuralml(Table Transformer) for hard borderless tables — plusflavor="auto"to pick one for you. - 🤖 Borderless & scanned — the optional
mlbackend (pip install "camelot-py[ml]") recovers structure that the heuristic parsers can't on borderless tables; add[ocr]to read scanned / image-only PDFs with no text layer. - 🧠 Vector + raster line detection —
engine="combined"unions the PDF's native vector ruled lines with OpenCV detection, so faintly-ruled tables are still found. - 🐼 pandas output — every table is a
DataFrame, ready for analysis. - 📤 Many export formats — CSV, JSON, Excel, HTML, Markdown, and SQLite.
- 📐 Quality metrics — accuracy, whitespace, and a confidence score per table; drop noise with
TableList.filter(...). - 🧩 Multi-page tables — stitch continuations across pages with
stack_contiguous(). - 🎛️ Highly configurable — table areas/regions, column separators, text processing, and more.
- 🔌 Flexible input — a file path, URL, raw
bytes, or any binary file-like object. - 🖥️ CLI included —
camelot lattice file.pdf, etc. - 📦 Light install — the default pdfium backend is bundled, with no system dependencies.
Extract tables from PDFs in just a few lines of code:
Try it yourself in our interactive quickstart notebook.
Or check out a simple example using this pdf.
>>> import camelot
>>> tables = camelot.read_pdf('foo.pdf')
>>> tables
<TableList n=1>
>>> tables.export('foo.csv', f='csv', compress=True) # json, excel, html, markdown, sqlite
>>> tables[0]
<Table shape=(7, 7)>
>>> tables[0].parsing_report
{
'accuracy': 99.02,
'whitespace': 12.24,
'order': 1,
'page': 1
}
>>> tables[0].to_csv('foo.csv') # to_json, to_excel, to_html, to_markdown, to_sqlite
>>> tables[0].df # get a pandas DataFrame!
| Cycle Name | KI (1/km) | Distance (mi) | Percent Fuel Savings | |||
|---|---|---|---|---|---|---|
| Improved Speed | Decreased Accel | Eliminate Stops | Decreased Idle | |||
| 2012_2 | 3.30 | 1.3 | 5.9% | 9.5% | 29.2% | 17.4% |
| 2145_1 | 0.68 | 11.2 | 2.4% | 0.1% | 9.5% | 2.7% |
| 4234_1 | 0.59 | 58.7 | 8.5% | 1.3% | 8.5% | 3.3% |
| 2032_2 | 0.17 | 57.8 | 21.7% | 0.3% | 2.7% | 1.2% |
| 4171_1 | 0.07 | 173.9 | 58.1% | 1.6% | 2.1% | 0.5% |
Camelot also comes packaged with a command-line interface!
Refer to the QuickStart Guide to quickly get started with Camelot, extract tables from PDFs and explore some basic options.
Tip: Visit the parser-comparison-notebook to get an overview of all the packed parsers and their features.
Note: The built-in parsers need a text-based PDF (as Tabula explains, "If you can click and drag to select text in your table in a PDF viewer, then your PDF is text-based"). For scanned / image-only PDFs, install the neural backend with OCR — pip install "camelot-py[ml,ocr]" — and use camelot.read_pdf(..., flavor="ml"): the model reads the structure from the page image and OCR supplies the text.
You can check out some frequently asked questions here.
Which parser should I use?
| Your PDF | Use | Why |
|---|---|---|
| Ruled tables (lines between cells) | flavor="lattice" (default) |
Deterministic; detects the grid from the ruled lines. engine="combined" also catches faint vector rules. |
| Borderless tables (whitespace-separated) | flavor="network" or "stream" |
Text-alignment / whitespace heuristics — fast, no extra dependencies. |
| Borderless tables, best quality | flavor="ml" (pip install "camelot-py[ml]") |
A Table Transformer model recovers structure heuristics can't — on FinTabNet it roughly doubles borderless TEDS vs network/hybrid. Heavier (PyTorch); opt-in. |
| Scanned / image-only PDFs (no text layer) | flavor="ml" + pip install "camelot-py[ml,ocr]" |
Structure from the model, text from OCR. |
| Mixed / not sure | flavor="auto" |
Picks lattice or network per page. |
The ml backend keeps Camelot honest: the model only supplies the table
structure, while cell text comes from the PDF's own text layer (or OCR
for scans) — so it never invents or alters a value.
Why Camelot?
- Configurability: Camelot gives you control over the table extraction process with tweakable settings.
- Metrics: You can discard bad tables based on metrics like accuracy and whitespace, without having to manually look at each table.
- Output: Each table is extracted into a pandas DataFrame, which seamlessly integrates into ETL and data analysis workflows. You can also export tables to multiple formats, which include CSV, JSON, Excel, HTML, Markdown, and Sqlite.
See comparison with similar libraries and tools.
Installation
Camelot's default image-conversion backend is pdfium, which ships as a wheel — so a plain install needs no system dependencies. The optional ghostscript and poppler backends require additional dependencies.
Using uv
uv is a fast Python package and project manager. To add Camelot to a project:
uv add camelot-py
Or to install it into the current environment:
uv pip install camelot-py
Using pip
pip install "camelot-py"
Using conda
conda is the package manager for the Anaconda distribution:
conda install -c conda-forge camelot-py
From the source code
git clone https://github.com/camelot-dev/camelot.git
cd camelot
uv pip install "." # or: pip install "."
Optional extras
pip install "camelot-py[ml]" # neural flavor='ml' (Table Transformer; pulls PyTorch)
pip install "camelot-py[ocr]" # OCR text source for scanned PDFs (use with [ml])
pip install "camelot-py[ml,ocr]" # both — borderless + scanned
pip install "camelot-py[plot]" # matplotlib debug plots
The core install stays light: [ml]/[ocr] are imported lazily, so a plain
import camelot never loads PyTorch or OCR.
Documentation
The documentation is available at http://camelot-py.readthedocs.io/.
Contributing
The Contributor's Guide has detailed information about contributing issues, documentation, code, and tests.
Versioning
Camelot uses Semantic Versioning. For the available versions, see the tags on this repository. For the changelog, you can check out the releases page.
License
This project is licensed under the MIT License, see the LICENSE file for details.
The documentation theme is licensed under a seperate BSD-like License, see the LICENSE file for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file camelot_py-2.0.0rc1.tar.gz.
File metadata
- Download URL: camelot_py-2.0.0rc1.tar.gz
- Upload date:
- Size: 138.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d233af624335e74ee8e3352277dda2b6b182d4bf67caae5f7887fe44c3ed442f
|
|
| MD5 |
39ff9c2c039b13048ef7457e97985ebb
|
|
| BLAKE2b-256 |
a7ef378bc2c6f930e052f50aa1d9bb6b24e888b02aafe2d723c044519962803a
|
Provenance
The following attestation bundles were made for camelot_py-2.0.0rc1.tar.gz:
Publisher:
release.yml on camelot-dev/camelot
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
camelot_py-2.0.0rc1.tar.gz -
Subject digest:
d233af624335e74ee8e3352277dda2b6b182d4bf67caae5f7887fe44c3ed442f - Sigstore transparency entry: 1629729362
- Sigstore integration time:
-
Permalink:
camelot-dev/camelot@c227afd189566f93fc489bf1c1ccb6136e2ee6e7 -
Branch / Tag:
refs/tags/v2.0.0rc1 - Owner: https://github.com/camelot-dev
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@c227afd189566f93fc489bf1c1ccb6136e2ee6e7 -
Trigger Event:
release
-
Statement type:
File details
Details for the file camelot_py-2.0.0rc1-py3-none-any.whl.
File metadata
- Download URL: camelot_py-2.0.0rc1-py3-none-any.whl
- Upload date:
- Size: 112.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9e150624069f9d9a43995d8a75a1a35df5af51a28725b0506bc850b3b19b91e4
|
|
| MD5 |
0c200cd82d0a40c22943e7bdf23c31d4
|
|
| BLAKE2b-256 |
65d54081700bd98c8ead5d2164d52a5b39e2bbac1b618691e7111e6bc4392bcc
|
Provenance
The following attestation bundles were made for camelot_py-2.0.0rc1-py3-none-any.whl:
Publisher:
release.yml on camelot-dev/camelot
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
camelot_py-2.0.0rc1-py3-none-any.whl -
Subject digest:
9e150624069f9d9a43995d8a75a1a35df5af51a28725b0506bc850b3b19b91e4 - Sigstore transparency entry: 1629729369
- Sigstore integration time:
-
Permalink:
camelot-dev/camelot@c227afd189566f93fc489bf1c1ccb6136e2ee6e7 -
Branch / Tag:
refs/tags/v2.0.0rc1 - Owner: https://github.com/camelot-dev
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@c227afd189566f93fc489bf1c1ccb6136e2ee6e7 -
Trigger Event:
release
-
Statement type: