rocketpdf is python-based powerful CLI app that take basic pdf operations and elevates the user experience to the next level, allowing the user to not only convert and modify existing pdf files, but to chain operations and get a polished final result in a single swing!
This project "concatenates" efforts of different open-source solutions like docx2pdf, pdf2docx or typer and creates a powerful tool for quickly managing and modifying pdf files from the console.
pip install rocketpdfTip
It is always recommended to open a terminal inside the directory you will be working.
| Command | Description |
|---|---|
parsedoc |
Converts .docx file into .pdf file. |
parsedocxs |
Converts all .docx files inside a directory into .pdf files. |
parsepdf |
Converts .pdf file into .docx file. |
merge |
Merges multiple .pdf files into a single.pdf file. |
mergeall |
Merges all .pdf files inside a directory into a single .pdf file. |
extract |
Extract a certain range of pages from a .pdf file. |
compress |
Reduces the size of .pdf file. |
parsedoc
Converts .docx file into .pdf file.
rocketpdf parsedoc sample.docx-o: Customize file output name. Default: {filename}.pdf.
parsedocxs
Converts all .docx files inside a directory into .pdf files.
rocketpdf parsedocxs C:\Users\user\samplesDefault: {filename}.pdf.
parsepdf
Converts .pdf file into .docx file.
rocketpdf parsepdf sample.pdf-o: Customize file output name. Default: {filename}.docx.
merge
Merges multiple .pdf files into a single.pdf file.
rocketpdf merge sample.pdf sample2.pdf sample3.pdf-o: Customize file output name. Default: merged.pdf.
mergeall
Merges all .pdf files inside a directory into a single .pdf file.
rocketpdf mergeall C:\Users\user\samples-o: Customize file output name. Default: {directory}-merged.pdf.
extract
Extract a certain range of pages from a .pdf file.
rocketpdf extract sample.pdf 2rocketpdf extract sample.pdf 2 4-o: Customize file output name. Default: {filename} page(s) # - #
compress
Reduces the size of .pdf file.
rocketpdf compress sample.pdf-o: Customize file output name. Default: {filename}-compressed.pdf.
rocketpdf is a powerful tool that allows users to execute multiple commands in a single line by passing the binary result of a file onto the next operation.
To chain multiple operations it is assumed that that the previous operations file result will be the input of the next command.
Let's download all monthly invoices into Invoices 2024 folder and compress the file for easier upload:
rocketpdf mergeall ".\Invoices 2024" compress -o Invoices_2024.pdf Let's convert my Resume.docx to .pdf and append my Cover_Letter.pdf
rocketpdf parsedoc Resume.docx merge Cover_Letter.pdf -o Job_Application.pdf Let's extract the first page of passsport.pdf and append my bank_deposit_info.pdf:
rocketpdf extract passport.pdf 1 merge bank_deposit_info.pdf -o payment_information.pdfCaution
parsedocis generally a starting command in a chain, so it cannot be used after any other operation.mergeallis generally a starting command in a chain, so it cannot be used after any other operation.parsedocxsis not chainable.parsepdfis not chainable (for now).
rocketpdf is compatible with _Windows_ and _Mac_ systems with MS Word installed.
Important
Unfortunately _Linux_ users cannot parse .docx files into .pdf files due to lack of libraries and support. The team (me) will be looking forward to bring a Linux-based solution in the near future.
Contributions are welcome! If you would like to contribute to this project, please follow these steps:
- Fork the Repository
- Clone the Repository to your local machine:
- Create a Branch
- Make Your Changes.
- Commit (and Detail) Your Changes.
- Push your changes.
- Open a Pull Request from your branch to the main branch of this repository. Provide a clear and descriptive title and description for your PR.
- Code Review and Merge
Important
Black was used as the code formatter for this project. Please ensure that your code is formatted with Black before submitting a pull request.
Install black via pip
pip install blackblack {source_file_or_directory}...Set as default formatter via VS Code extension
"[python]": {
"editor.defaultFormatter": "ms-python.black-formatter",
"editor.formatOnSave": true
}