A bulk pdf generator. This application can generate PDFs in bulk by using just one click.

Overview

logo

forks-badge stars-badge watcher-badge repo_size-badge CodeFactor

A bulk html pdf generator. This application can generate PDFs in bulk by using just one click.

Screenshots

demo1 demo2

Requirements 🧱

Your system must have the following tools installed and setup with system path variables updated before you can use this software.

  • Python3
  • pip package manager
  • GTK3 Runtime (for Windows, MacOS and few linux based systems). You can get GTK form here πŸ‘‰ For Windows, For MacOS, For Linux

    Note: Your system might already have gtk3 installed. You need not install gtk dev dependencies.

Getting started πŸš€

To run the application from the source code you need to meet few basic requirements. Once that is done we are ready to do the setup.

To prepare the environment you need to follow these steps:

  • Execute the prep.sh script which will make virtual environment. Here is an example for debian based system:

    $ chmod +x prep.sh
    $ ./prep.sh
  • Now we can activate the environment. Here is an example:

    • For Unix or MacOS based system:

      $ source env/bin/activate
    • For Windows based system:

      $ env\Scripts\activate.bat

      Note: Your pwd must be the src directory or else you need to provide full path of the activate script.

    • To deactivate use the following command:

      $ deactivate
  • Now we are ready to install the required packages. Run the following command to install all the required packages:

    $ pip install -r requirements.txt
  • Once we are done with installing packages. We are ready to execute the application using python. Here is an example:

    $ python app.py

Note: To run this software successfully you need to make sure you have GTK3 installed.

How to use? πŸ’‘

When the application is launched it has a single window with a few but important options. The application uses special syntax to generate customized content. Lets have a brief walk through it:

The application uses HTML and CSS to render document designs. We have provided some pre-build templates but feel free to load your custom design.

Template variable syntax πŸ”₯

To make the document generation versatile and make customization possible we added a variable syntax in system for the templates which will be used to render real value from the data file.

  • A variable is surrounded by %.

    Example: %label%

  • A label is the column name of the data file. It is the first row of the .csv file.
Number Alpha Beta Gamma πŸ‘ˆ These are the labels
1 100 40 0.5
2 90 80 0.7
3 150 20 0.1

Note: Labels are case sensitive.

Here is an example

template.html

Certificate of Completion

This is to certify that

%Name%

has completed the course

%Course%

with score of %Score%



">
<style>
  @page {
    size: 890px 690px;
    margin: auto;
  }
style>
<div
  style="width:800px; height:600px; padding:20px; text-align:center; border: 10px solid #787878"
>
  <div
    style="width:750px; height:550px; padding:20px; text-align:center; border: 5px solid #787878"
  >
    <span style="font-size:50px; font-weight:bold"
      >Certificate of Completionspan
    >
    <br /><br />
    <span style="font-size:25px"><i>This is to certify thati>span>
    <br /><br />
    <span style="font-size:30px"><b>%Name%b>span ><br /><br /> <span style="font-size:25px"><i>has completed the coursei>span> <br /><br /> <span style="font-size:30px">%Course%span> <br /><br /> <span style="font-size:20px">with score of <b>%Score%b>span> <br /><br /><br /><br /> div> div>
data.csv
Name Course Score πŸ‘ˆ These are the labels
Aman Nirala Quantum Information 95

PDF output

Steps to use 🧐

  1. Select your HTML template file in the application (this file is important).
  2. Select style(css) file for additional design customization (optional).
  3. Then choose your data file(.csv).

    Note: The data file needs to be a .csv i.e. comma(,) separated file. The first row is considered as "label" information and not data instance. This is important as this "label" will be used in the template file as variables.

  4. Next you need to define an output file name format. This is optional, you can leave is empty and it will auto-generate file name based on the data.

    Note: You have to follow variable syntax format for defining file name. Here is an example: %label-1%_MIT_%label-2%.pdf.

  5. Now you need to select the output directory in which all the documents will be saved.
  6. Finally it's time to do a final check and tweaks before staring the document generation process.(Don't forget to save the changes made to the template or style files in the application before starting to process.)
  7. Once everything is done, press the Generate button and wait for the program to finish the process.

License

FOSSA Status

Contributors ✨

All Contributors

Thanks goes to these wonderful people (emoji key):


Aman Nirala

πŸ’» πŸ“– πŸ€” 🎨

This project follows the all-contributors specification. Contributions of any kind welcome!


github_follow_badge twitter-badge

If you like our work, a bit of contribution would motivate us a lot for more open source contributions.

Owner
Aman Nirala
Computer Science and Physics student. Quantum Computing and Mechanics Researcher. Reclusive like a neutrino. A photon to the higgs field of giving up.
Aman Nirala
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 09, 2021
Python lib for Simple PDF text extraction

Python lib for Simple PDF text extraction

Jason Alan Palmer 651 Jan 01, 2023
Table automatically extraction from PDF Document

PDF Table Extractor Table automatically extraction from PDF Document Our Icon πŸ“Œ Name : PDF Table Extractor πŸ“Œ Authors : Minku Koo Jiyong Park πŸ“Œ Deve

1 Jan 10, 2022
Pdfencrypt is a tool to encrypt/lock PDFs

Pdfencrypt Pdfencrypt is a tool to encrypt/lock PDFs Installation $ apt update $ apt upgrade $ apt install git $ apt install python $ git clone https:

Anontemitayo 5 Nov 28, 2021
Simple pdf editor while preserving structure and format.

SIMPdf Simple pdf editor while preserving structure and format.

Shashwat Singh 242 Jan 04, 2023
Excalibur: A web interface to extract tabular data from PDFs

Excalibur: A web interface to extract tabular data from PDFs Excalibur is a web interface to extract tabular data from PDFs, written in Python 3! It i

1.2k Jan 04, 2023
CLI tool to generate pdf invoices written in python

invoicepy CLI invoice tool, store and print invoices as pdf. save companies and customers for later use. installation pip install invoicepy config co

Adam Wojtczak 9 Aug 01, 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 07, 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 09, 2022
pdf_sprinkles: sprinkles text in your PDFs

pdf_sprinkles: sprinkles text in your PDFs pdf_sprinkles remotely OCRs a PDF with Google Cloud Document AI, and returns the result as a PDF with searc

Will Angley 2 Dec 17, 2021
Camelot is a Python library that makes it easy for anyone to extract tables from PDF files

Camelot: PDF Table Extraction for Humans Camelot is a Python library that makes it easy for anyone to extract tables from PDF files! Note: You can als

Atlan Technologies Pvt Ltd 3.3k Jan 06, 2023
Convert Lecture Videos to PDF

Convert Lecture Videos to PDF Description Want to go through lecture videos faster without missing any information? Wish you can read the lecture vide

Emilio Kartono 20 Nov 25, 2022
rst2pdf: Use a text editor. Make a PDF.

rst2pdf: Use a text editor. Make a PDF.

rst2pdf 487 Jan 06, 2023
DietPDF aims at reducing PDF file size while not degrading quality nor losing metadata

DietPDF aims at reducing PDF file size while not degrading quality nor losing metadata

FrΓ©dΓ©ric BISSON 6 Jul 27, 2022
Simple python tool created for downloading PDF.

PDFdownloader Usage Open PDF in full-screen mode Run scan.exe Enter how many pages you want to scan Focus PDF After scanning is done, run merge.exe En

5 Oct 27, 2021
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
WeasyPrint is a smart solution helping web developers to create PDF documents.

WeasyPrint is a smart solution helping web developers to create PDF documents. It turns simple HTML pages into gorgeous statistical reports, invoices, tickets…

Kozea 5.4k Jan 08, 2023
A bot for PDF for doing Many Things....

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

Mr. Developer 60 Dec 27, 2022
Svg2pdfgen - Svg To PDF gen with python

Svg2pdfgen - Svg To PDF gen with python

Robert UrbaΕ„czyk 3 May 30, 2022
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 03, 2022