Camelot is a Python library that makes it easy for anyone to extract tables from PDF files

Overview

Camelot: PDF Table Extraction for Humans

Build Status Documentation Status codecov.io image image image Gitter chat image

Camelot is a Python library that makes it easy for anyone to extract tables from PDF files!

Note: You can also check out Excalibur, which is a web interface for Camelot!


Here's how you can extract tables from PDF files. Check out the PDF used in this example here.

>>> import camelot
>>> tables = camelot.read_pdf('foo.pdf')
>>> tables

  
>>> tables.export('foo.csv', f='csv', compress=True) # json, excel, html, sqlite
>>> tables[0]

  
   
>>> 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_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%

There's a command-line interface too!

Note: Camelot only works with text-based PDFs and not scanned documents. (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".)

Why Camelot?

  • You are in control.: Unlike other libraries and tools which either give a nice output or fail miserably (with no in-between), Camelot gives you the power to tweak table extraction. (This is important since everything in the real world, including PDF table extraction, is fuzzy.)
  • Bad tables can be discarded based on metrics like accuracy and whitespace, without ever having to manually look at each table.
  • Each table is a pandas DataFrame, which seamlessly integrates into ETL and data analysis workflows.
  • Export to multiple formats, including JSON, Excel, HTML and Sqlite.

See comparison with other PDF table extraction libraries and tools.

Installation

Using conda

The easiest way to install Camelot is to install it with conda, which is a package manager and environment management system for the Anaconda distribution.

$ conda install -c conda-forge camelot-py

Using pip

After installing the dependencies (tk and ghostscript), you can simply use pip to install Camelot:

$ pip install camelot-py[cv]

From the source code

After installing the dependencies, clone the repo using:

$ git clone https://www.github.com/camelot-dev/camelot

and install Camelot using pip:

$ cd camelot
$ pip install ".[cv]"

Documentation

Great documentation is available at http://camelot-py.readthedocs.io/.

Development

The Contributor's Guide has detailed information about contributing code, documentation, tests and more. We've included some basic information in this README.

Source code

You can check the latest sources with:

$ git clone https://www.github.com/camelot-dev/camelot

Setting up a development environment

You can install the development dependencies easily, using pip:

$ pip install camelot-py[dev]

Testing

After installation, you can run tests using:

$ python setup.py test

Versioning

Camelot uses Semantic Versioning. For the available versions, see the tags on this repository. For the changelog, you can check out HISTORY.md.

License

This project is licensed under the MIT License, see the LICENSE file for details.

Comments
  • 'Please make sure that Ghostscript is installed' error when it is already successfully installed

    'Please make sure that Ghostscript is installed' error when it is already successfully installed

    Facing issue when tried to run following code:

    import camelot tables = camelot.read_pdf('test.pdf')

    Error:

    tables = camelot.read_pdf('Unaudited-Financial-Results.pdf') Traceback (most recent call last): File "C:\Users\hp1\Anaconda2\envs\lib\site-packages\camelot\parsers\la ttice.py", line 193, in get_executable raise ValueError ValueError

    During handling of the above exception, another exception occurred:

    Traceback (most recent call last): File "", line 1, in File "C:\Users\hp1\Anaconda2\envs\lib\site-packages\camelot\io.py", li ne 101, in read_pdf tables = p.parse(flavor=flavor, **kwargs) File "C:\Users\hp1\Anaconda2\envs\lib\site-packages\camelot\handlers.p y", line 157, in parse t = parser.extract_tables(p) File "C:\Users\hp1\Anaconda2\envs\lib\site-packages\camelot\parsers\la ttice.py", line 356, in extract_tables self._generate_image() File "C:\Users\hp1\Anaconda2\envs\lib\site-packages\camelot\parsers\la ttice.py", line 220, in _generate_image gs = get_executable() File "C:\Users\hp1\Anaconda2\envs\lib\site-packages\camelot\parsers\la ttice.py", line 206, in get_executable 'Please make sure that Ghostscript is installed' camelot.parsers.lattice.GhostscriptNotFound: Please make sure that Ghostscript i s installed and available on the PATH environment variable

    When checked in cmd for GhostScript it shows successfully installed and Path is set correctly:

    C:>gswin64c.exe -version GPL Ghostscript 9.25 (2018-09-13) Copyright (C) 2018 Artifex Software, Inc. All rights reserved.

    Also, instead of lattice, if stream method is used, a csv file can be generated successfully:

    tables = camelot.read_pdf('test.pdf', flavor='stream', table_area tables

    >>> tables.export('test.csv', f='csv', compress=True)

    Requesting to fix above mentioned issue.

    opened by narsinha 43
  • ImportError

    ImportError

    `--------------------------------------------------------------------------- ImportError Traceback (most recent call last) in () 1 import pandas as pd ----> 2 import camelot

    /Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/site-packages/camelot/init.py in () 4 5 from .version import version ----> 6 from .io import read_pdf 7 8

    /Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/site-packages/camelot/io.py in () 1 # -- coding: utf-8 -- 2 ----> 3 from .handlers import PDFHandler 4 from .utils import validate_input, remove_extra 5

    /Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/site-packages/camelot/handlers.py in () 5 from PyPDF2 import PdfFileReader, PdfFileWriter 6 ----> 7 from .core import TableList 8 from .parsers import Stream, Lattice 9 from .utils import (TemporaryDirectory, get_page_layout, get_text_objects,

    ImportError: cannot import name 'TableList'`

    opened by enolette 28
  • [MRG + 1] Create a new figure and test each plot type #127

    [MRG + 1] Create a new figure and test each plot type #127

    • move plot() to plotting.py as plot_pdf()
    • add filename param to plot_pdf()
    • modify plotting functions to return matplotlib figures
    • add test_plotting.py and baseline images
    • import plot_pdf() in __init__
    • update cli.py to use plot_pdf()
    • update advanced usage docs to reflect changes
    opened by Suyash458 18
  • Not able to read multiple pages using pages='1,2,3' or pages='all'

    Not able to read multiple pages using pages='1,2,3' or pages='all'

    When I am reading a pdf filw with multiple pages, I am only getting first page by default.

    When I am using this code read_pdf(sample.pdf, pages='1-2') or read_pdf(sample.pdf, pages='all') or read_pdf(sample.pdf, pages='1,2') I am getting following error.

    AttributeError: 'PDFHandler' object has no attribute 'password'

    Can you please fix this issue

    bug 
    opened by ghost 15
  • Please add support for reading tables with Arabic fonts

    Please add support for reading tables with Arabic fonts

    Versions: Linux-4.9.0-6-amd64-x86_64 Python 3.6.5 |Anaconda, Inc.| (default, Apr 29 2018, 16:14:56) [GCC 7.2.0] NumPy 1.15.2 OpenCV 3.4.2

    Hi,

    Can you please support reading languages in Arabic fonts?

    In particular, I'm trying to extract tables from this document (backup link since Scribd seems to be down right now).

    Starting at page 6, the document presents lines of Arabic on the left column and lines of English in the right column. I used these commands to extract that text as a table:

    tables = camelot.read_pdf('quran.pdf', pages='6',columns=['240'])
    tables.export('quran.csv', f='csv', compress=False)
    

    However, the extracted table has two issues:

    1. The (I think unicode) characters for the Arabic text seem to have either been corrupted in the process or they've lost any mapping to the Arabic fonts. Even when I tried opening up the file in Google Sheets & other editors and set the font to Arabic the words would still not be properly displayed

    2. Text that should have been on the same row of two different rows is instead placed in two different columns of the same row. (This is a minor annoyance that I can easily work around, and perhaps you tool already has a fix for this that I haven't discovered)

    Below is the full output generated by the above command. Interestingly, in the beginning part of the file (line 3 and a bit of line 4) you can at least recognize the Arabic letters. However, again there are two issues:

    1. The order of the letters has been flipped around. This is probably due to the fact that Arabic reads from right to left. I suspect PDFminer gave Camelot the letters in the "correct" left to right order, but Camelot, not being aware that the letters should be read in the opposite order, flipped the order around
    2. The two lines of visible Arabic are both from the same word, the characters of which somehow got split into two different rows
    "ِ",""
    "",""
    "ِةِِ حـِتاَف",""
    "ْلَا","al-Fātiḥah"
    "َ",""
    "",""
    "","1.  1In the Name of Allah,"
    "",""
    "","the All-beneficent, the All-merciful."
    "",""
    "","2. All praise belongs to Allah,2"
    "",""
    "",""
    "","Lord of all the worlds,"
    "",""
    "","3. the All-beneficent, the All-merciful,"
    "",""
    "","4. Master3 of the Day of Retribution."
    "",""
    "","5. You [alone] do we worship,"
    "",""
    "","and to You [alone] do we turn for help."
    "",""
    "","6. Guide us on the straight path,"
    "",""
    "","7. the path of those whom You have blessed4"
    "",""
    "","—such as5 have not incurred Your wrath,6"
    "1 That is, ‘the opening’ sūrah. Another common name of the sūrah is ‘Sūrat al-Ḥamd, ’that is, the sūrah of",""
    "the [Lord’s] praise.",""
    "2 In Muslim parlance the phrase al-ḥamdu lillāh also signifies ‘thanks to Allah.’",""
    "3 This is in accordance with the reading mālik yawm al-dīn, adopted by ‘Āṣim, al-Kisā’ī, Ya‘qūb al-Ḥaḍramī,",""
    "and Khalaf. Other authorities of qirā’ah (the art of recitation of the Qur’ān) have read ‘malik yawm al-",""
    "","dīn,’meaning ‘Sovereign of the Day of Retribution’(see Mu‘jam al-Qirā’āt al-Qur’āniyyah). Traditions ascribe"
    "both readings to Imam Ja‘far al-Ṣādiq (‘a). See al-Qummī, al-‘Ayyāshī, Tafsīr al-Imām al-‘Askarī.",""
    "4 For further Qur’ānic references to ‘those whom Allah has blessed,’see 4:69 and 19:58; see also 5:23, 110;",""
    "12:6; 27:19; 28:17; 43:59; 48:2.",""
    "5 This is in accordance with the qirā’ah of ‘Āṣim, ghayril-maghḍūbi, which appears in the Arabic text above.",""
    "","However, in accordance with an alternative, and perhaps preferable, reading ghayral-maghḍūbi (attributed"
    
    bug 
    opened by ZainRizvi 15
  • can not parse Chinese pdf document

    can not parse Chinese pdf document

    This is the file I want to parse. W020180518365531252048.pdf PdfReadWarning: Illegal character in Name Object [generic.py:489] Traceback (most recent call last): File "D:\Python\Python36\lib\site-packages\IPython\core\interactiveshell.py", line 2961, in run_code exec(code_obj, self.user_global_ns, self.user_ns) File "", line 1, in tables = camelot.read_pdf("W020180518365531252048.pdf") File "D:\Python\Python36\lib\site-packages\camelot\io.py", line 91, in read_pdf tables = p.parse(flavor=flavor, **kwargs) File "D:\Python\Python36\lib\site-packages\camelot\handlers.py", line 141, in parse self._save_page(self.filename, p, tempdir) File "D:\Python\Python36\lib\site-packages\camelot\handlers.py", line 95, in save_page layout, dim = get_page_layout(fpath) File "D:\Python\Python36\lib\site-packages\camelot\utils.py", line 586, in get_page_layout document = PDFDocument(parser) File "D:\Python\Python36\lib\site-packages\pdfminer.six-20170720-py3.6.egg\pdfminer\pdfdocument.py", line 566, in init xref.load(parser) File "D:\Python\Python36\lib\site-packages\pdfminer.six-20170720-py3.6.egg\pdfminer\pdfdocument.py", line 195, in load (, obj) = parser.nextobject() File "D:\Python\Python36\lib\site-packages\pdfminer.six-20170720-py3.6.egg\pdfminer\psparser.py", line 606, in nextobject raise PSSyntaxError('Invalid dictionary construct: %r' % objs) pdfminer.psparser.PSSyntaxError: Invalid dictionary construct: [/'Type', /'Font', /'Subtype', /'Type0', /'BaseFont', /b"b'", /"ABCDEE+\xb7\xc2\xcb\xce'", /'Encoding', /'Identity-H', /'DescendantFonts', PDFObjRef:6, /'ToUnicode', PDFObjRef:12]

    opened by yuyangyoung 14
  • [MRG] Replace gs subprocess call

    [MRG] Replace gs subprocess call

    This is a cleaner way to interact with the ghostscript, need to see if this PyPI package is available in anaconda or not. Also need to suppress the unnecessary logs generated by ghostscript.

    EDIT: If it isn't available, maybe we could vendorize it.

    Closes #152.

    opened by vinayak-mehta 14
  • read-pdf not part of camelot module??

    read-pdf not part of camelot module??

    My code

    tables = camelot.read_pdf("./test/spyglass.pdf")
    

    The error:

    Traceback (most recent call last):
      File "camelot.py", line 1, in <module>
        import camelot
      File "/Users/milad/Desktop/projects/shamrock/camelot.py", line 2, in <module>
        tables = camelot.read_pdf("./test.pdf");
    AttributeError: 'module' object has no attribute 'read_pdf'
    
    opened by Miladinho 14
  • Create a new figure and test each plot type

    Create a new figure and test each plot type

    Camelot supports plotting of 5 types of geometries for debugging and tweaking parser configurations.

    Plotting needs to be refactored in such a way that all plot functions return a matplotlib figure, so that they can be tested either by using pytest or matplotlib's image_comparison decorator. You can also check how pandas tests plots.

    The user should be given an option to save their plots, in addition to the current option of just displaying the figure, which might fail when there are no screens available.

    The new plots should also be tested to work in Jupyter notebooks.

    enhancement moderate help wanted 
    opened by vinayak-mehta 13
  • NotImplementedError: only algorithm code 1 and 2 are supported

    NotImplementedError: only algorithm code 1 and 2 are supported

    Having trouble running this code on my mac. Using Conda virtual env and installed using conda. Pdf is not password protected.

    import camelot import pandas as pd import re import numpy as np table1 = camelot.read_pdf('IEEJ - 2019 - Outlook.pdf')


    NotImplementedError Traceback (most recent call last) in ----> 1 table1 = camelot.read_pdf('IEEJ - 2019 - Outlook.pdf')#, pages = ex_page, password = None)#, area = (left, 112, right,112+ 90)) 2 table1

    /anaconda3/envs/tensorflow/lib/python3.6/site-packages/camelot/io.py in read_pdf(filepath, pages, password, flavor, suppress_stdout, layout_kwargs, **kwargs) 104 kwargs = remove_extra(kwargs, flavor=flavor) 105 tables = p.parse(flavor=flavor, suppress_stdout=suppress_stdout, --> 106 layout_kwargs=layout_kwargs, **kwargs) 107 return tables

    /anaconda3/envs/tensorflow/lib/python3.6/site-packages/camelot/handlers.py in parse(self, flavor, suppress_stdout, layout_kwargs, **kwargs) 153 with TemporaryDirectory() as tempdir: 154 for p in self.pages: --> 155 self._save_page(self.filepath, p, tempdir) 156 pages = [os.path.join(tempdir, 'page-{0}.pdf'.format(p)) 157 for p in self.pages]

    /anaconda3/envs/tensorflow/lib/python3.6/site-packages/camelot/handlers.py in _save_page(self, filepath, page, temp) 98 infile = PdfFileReader(fileobj, strict=False) 99 if infile.isEncrypted: --> 100 infile.decrypt(self.password) 101 fpath = os.path.join(temp, 'page-{0}.pdf'.format(page)) 102 froot, fext = os.path.splitext(fpath)

    /anaconda3/envs/tensorflow/lib/python3.6/site-packages/PyPDF2/pdf.py in decrypt(self, password) 1985 self._override_encryption = True 1986 try: -> 1987 return self._decrypt(password) 1988 finally: 1989 self._override_encryption = False

    /anaconda3/envs/tensorflow/lib/python3.6/site-packages/PyPDF2/pdf.py in _decrypt(self, password) 1994 raise NotImplementedError("only Standard PDF encryption handler is available") 1995 if not (encrypt['/V'] in (1, 2)): -> 1996 raise NotImplementedError("only algorithm code 1 and 2 are supported") 1997 user_password, key = self._authenticateUserPassword(password) 1998 if user_password:

    NotImplementedError: only algorithm code 1 and 2 are supported

    opened by nelsonlin2708968 12
  • Bring back OCR in a future release

    Bring back OCR in a future release

    The experimental version exists before this commit 9753889ea266c3b8e412d77eb411617ec40d8393. It uses Tesseract (using pyocr). ocropy looked promising the last time I checked, opening this issue for discussion and experiments around OCR.

    An earlier issue around the same topic: #14

    enhancement 
    opened by vinayak-mehta 12
  • pdf file with multi pages can't parse fully,the second page's tables can not display

    pdf file with multi pages can't parse fully,the second page's tables can not display

    a pdf file has tow pages ,the first page has 3 tables,the second has 2 tables. but when use camelot.read_pdf ,with parameter: pages='all', the result return only 3 tables,not 5 tables.

    import camelot tables = camelot.read_pdf('a22.pdf',pages='all') tables

    why return only 3 tables? thanks the source pdf is here: a22.pdf

    opened by cheneygan 1
  • Problems with pages with no tables - total number of pages variable, no good page indexing

    Problems with pages with no tables - total number of pages variable, no good page indexing

    Hello,

    There is a daily pdf report whose last page has no tables, but whose total number of pages vary each day.

    I cannot extract 'all' when there is a page with no table: _

    File ~\anaconda3\lib\site-packages\camelot\io.py:113 in read_pdf tables = p.parse(

    File ~\anaconda3\lib\site-packages\camelot\handlers.py:176 in parse t = parser.extract_tables(

    File ~\anaconda3\lib\site-packages\camelot\parsers\stream.py:456 in extract_tables self._generate_table_bbox()

    File ~\anaconda3\lib\site-packages\camelot\parsers\stream.py:310 in _generate_table_bbox table_bbox = self._nurminen_table_detection(hor_text)

    File ~\anaconda3\lib\site-packages\camelot\parsers\stream.py:287 in _nurminen_table_detection table_bbox = textedges.get_table_areas(textlines, relevant_textedges)

    File ~\anaconda3\lib\site-packages\camelot\core.py:221 in get_table_areas average_textline_height = sum_textline_height / float(len(textlines))

    ZeroDivisionError: float division by zero

    _

    And cannot index the reading pages from first to second to last, as I cannot know beforehand the total number of pages.

    Can you help me out?

    opened by Bernardo-Hazan 2
  • Do you have stream + only vertical lines seperation?

    Do you have stream + only vertical lines seperation?

    Hello,

    I am working with a pdf which I can not share due to confidentiality, however my question and issue is very simple. The pdf format is what we call "stream" BUT with vertical tabular lines between each column. So in the end I dont have row-lines but have column-lines.

    When I use camelot like this: camelot.read_pdf('mypdf.pdf', flavor="stream", pages="all", split_text=True)

    since my 2 columns are very close to each other (but seperated with the line I mentioned) camelot merges these two columns even I use split_text = True. Is there a harmonic method available for me to use "stream" but with appying vertial -OR- horizontal line avareness to the conversion.

    I know that I can use manual-inputted column cut point coordinate with "split" parameter but all my pdf files arrives with different split coordination so I can not hardcode some points. All I have in common is these vertical column seperator lines.

    Do you have a built-in solution for solving these kind of problems? If not, do you have a plan to add it in upcoming releases?

    Best.

    opened by Erenaliaslangiray 0
  • OSError: Ghostscript Installation error

    OSError: Ghostscript Installation error

    Even if i am using all these on Google colab to correctly install camelot, I am getting error when reading pdfs. It should not be this hard to install a simple library and run one line of code. If there is other way around, please let me know.

    pip uninstall camelot
    pip uninstall camelot-py
    pip install camelot-py[cv]
    
    # install ghostscript
    ! apt install ghostscript python3-tk
    ! pip install ghostscript
    

    Error log from Google COLAB OSError: Ghostscript is not installed. You can install it using the instructions here: https://camelot-py.readthedocs.io/en/master/user/install-deps.html

    opened by elvinagam 0
  • AttributeError: module 'camelot' has no attribute 'read_pdf'

    AttributeError: module 'camelot' has no attribute 'read_pdf'

    This issue appears to have arisen repeatedly, and I have tried the fixes previously posted. Thanks for any help you can provide.

    • I have installed the correct version of camelot, and I have tried uninstalling and reinstalling. pip install "camelot-py[base]". The same issue arose using other modifiers recommended ("[cv]", "[all]").

    • I have run import camelot.io as camelot. This does not produce the AttributeError, or any error message, but the resulting TableList object is empty (<TableList n=0>)

    • Dependencies are installed and up-to-date: ghostcript (9.56.1) and tcl-tk (8.6.12_1). I am able to import tkinter, and find_library("gs") returns '/usr/local/lib/libgs.dylib'.

    opened by esoltas 0
Releases(v0.7.2)
Owner
Atlan Technologies Pvt Ltd
Democratizing data for teams around the world :sparkles: Humans of data, welcome home :heart:
Atlan Technologies Pvt Ltd
PyPDF2 is a pure-python PDF library capable of splitting, merging together, cropping, and transforming the pages of PDF files.

PyPDF2 is a pure-python PDF library capable of splitting, merging together, cropping, and transforming the pages of PDF files. It can also add custom data, viewing options, and passwords to PDF files. It can retrieve text and metadata from PDFs as well as merge entire files together.

Matthew Stamy 5k Jan 4, 2023
Compare-pdf - A Flask driven restful API for comparing two PDF files

COMPARE-PDF A Flask driven restful API for comparing two PDF files. Description

Karthikeyan JC 3 Mar 13, 2022
Trata PDF para torná-lo compatível com PDF/X e com impressoras em escala de cinza.

tratapdf Trata PDF para torná-lo compatível com PDF/X e com impressoras em escala de cinza. dependências icc-profiles ghostscript visualizador de PDF

null 1 Nov 30, 2021
Convert PDF to AudioBook and Audio Speech to PDF

In this Python project, we will build a GUI-based PDF to Audio and Audio to PDF converter using the Tkinter, OS, path, pyttsx3, SpeechRecognition, PyPDF4, and Pydub libraries and the messagebox module of the Tkinter library.

RISHABH MISHRA 1 Feb 13, 2022
Extract the table in the PDF,outputs the data similar to the json format

extract the table in the PDF,outputs the data similar to the json format

null 3 Nov 25, 2021
borb is a library for reading, creating and manipulating PDF files in python.

borb is a library for reading, creating and manipulating PDF files in python.

Joris Schellekens 2.9k Jan 1, 2023
pikepdf is a Python library for reading and writing PDF files.

A Python library for reading and writing PDF, powered by qpdf

null 1.6k Jan 3, 2023
Python script that split PDF files.

Automatic PDF Splitter This script can create new single-page PDFs files from multipaged PDFs. Requirements Python 3.0+ # Debian distros sudo apt-get

Leandro Padula 5 Apr 2, 2022
Converting Html files to pdf using python script, pdfkit module and wkhtmltopdf.

Html-to-pdf-pdfkit-wkhtml- This repository has code for converting local html files and online html resources into pdf. It is an python script which u

Hemachandran P 1 Nov 9, 2021
pystitcher stitches your PDF files together, generating nice customizable bookmarks for you using a declarative markdown file as input

pystitcher pystitcher stitches your PDF files together, generating nice customizable bookmarks for you using a declarative input in the form of a mark

Nemo 387 Dec 10, 2022
Generate a bunch of malicious pdf files with phone-home functionality. Can be used with Burp Collaborator

Malicious PDF Generator ☠️ Generate ten different malicious pdf files with phone-home functionality. Can be used with Burp Collaborator. Used for pene

Jonas Lejon 1.9k Jan 1, 2023
Merge multiple PDF files into one.

PDF Merger Merge multiple PDF files into one. Usage % python pdf_merger.py -h usage: pdf_merger.py [-h] [-o OUTPUT] [-f [FILES ...]] optional argumen

Duo Apps 6 Oct 3, 2022
Program that locks/unlocks pdf files🐍

?? ?? PDFtools ?? ?? Programa que bloqueia/desbloqueia arquivos pdf Requisitos • Como usar • Capturas de Tela ?? Aviso ?? Altere os caminhos referente

João Victor Vilela dos Santos 1 Nov 4, 2021
Telegram bot that can do a lot of things related to PDF files.

Telegram PDF Bot A Telegram bot that can: Compress, crop, decrypt, encrypt, merge, preview, rename, rotate, scale and split PDF files Compare text dif

null 130 Dec 26, 2022
Convert MD files to PDF automatically (with CSS) 📄🚀

MD2PDF Action Convert MD files to PDF automatically (with CSS)! Converts a pattern described set of markdown files and converts them to pdf whilst app

Will Fantom 1 Feb 9, 2022
A python library for extracting text from PDFs without losing the formatting of the PDF content.

Multilingual PDF to Text Install Package from Pypi Install it using pip. pip install multilingual-pdf2text The library uses Tesseract which can be ins

Shahrukh Khan 49 Nov 7, 2022
x-ray is a Python library for finding bad redactions in PDF documents.

A tool to detect whether a PDF has a bad redaction

Free Law Project 73 Dec 19, 2022
This book will take you on an exploratory journey through the PDF format, and the borb Python library.

This book will take you on an exploratory journey through the PDF format, and the borb Python library.

Joris Schellekens 281 Jan 1, 2023
Simple HTML and PDF document generator for Python - with built-in support for popular data analysis and plotting libraries.

Esparto is a simple HTML and PDF document generator for Python. Its primary use is for generating shareable single page reports with content from popular analytics and data science libraries.

Dom 76 Dec 12, 2022