Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/josee9988/compress-pdfs

A python CLI script to π—°π—Όπ—Ίπ—½π—Ώπ—²π˜€π˜€ πŸ“¦ all the 𝗣𝗗𝗙 files π—Ώπ—²π—°π˜‚π—Ώπ˜€π—Άπ˜ƒπ—²π—Ήπ˜† in a directory using the iLovePDF technology πŸ₯°
https://github.com/josee9988/compress-pdfs

compress compress-files compress-pdf compressed compression compressor compressors pdf pdf-compression pdf-converter pdf-document-processor pdf-files python python-3 python-compressing python-pdf python3 python3-script python3-scripts size-reduction

Last synced: 26 days ago
JSON representation

A python CLI script to π—°π—Όπ—Ίπ—½π—Ώπ—²π˜€π˜€ πŸ“¦ all the 𝗣𝗗𝗙 files π—Ώπ—²π—°π˜‚π—Ώπ˜€π—Άπ˜ƒπ—²π—Ήπ˜† in a directory using the iLovePDF technology πŸ₯°

Awesome Lists containing this project

README

        

# πŸ“¦ **Josee9988/Compress-PDFs**



Issues


GitHub pull requests

⚠️This project is not fully finished or tester, it might cause some errors with in certain situations. Please, do a backup of the folders you want to compress before using this script.⚠️

---

## πŸ€” **About the project**

* A CLI tool to compress πŸ“¦ all PDFs recursively in a directory.

---

## ⚑ **Installation**

1. Clone the repository and `cd` into it

```bash
git clone [email protected]:Josee9988/Compress-PDFs.git && cd Compress-PDFs
```

2. *Install pip3*

```bash
sudo apt install python3-pip
# verify it with pip3 --version
```

3. Instal the ilovepdf dependency

```bash
pip3 install pylovepdf
```

4. Make the script executable from anywhere

```bash
bash MAKE_SCRIPT_GLOBAL.sh
```

5. Rename `.env.example` to `.env`.

```bash
mv -v .env.example .env # rename to .env
```

6. Add your [IlovePDF](https://developer.ilovepdf.com/) public key

* Modify the `.env` file add update the **`PUBLIC_KEY`** variable with your public key from [the IlovePDF developer's site](https://developer.ilovepdf.com/)

7. Run it ;)

```bash
compress.py /RELATIVE/OR/ABSOLUTE/PATH/TO/YOUR/DIR/
```

---

## πŸš€ **Usage**

* After running the script `MAKE_SCRIPT_GLOBAL.sh` you can call the script from anywhere in your system with: `compress.py `

* The script receives only one argument and it is the path of the directory that will be recursively compressed. All the subfolders will be looked up to compress all the pdfs inside the passed directory as an argument.

* Script profile

```bash
compress.py
```

* Some examples of usage

1. Using an absolute path

```bash
compress.py /home/username/Documents/MyFolder
```

2. Using a relative path

```bash
compress.py .
```

```bash
compress.py /dirFromWhereIAm/whatever/
```

---

## 🌲 **Project tree**

```bash
.
β”œβ”€β”€ compress.py
β”œβ”€β”€ .env
β”œβ”€β”€ .github
β”‚ β”œβ”€β”€ CODE_OF_CONDUCT.md
β”‚ β”œβ”€β”€ CODEOWNERS
β”‚ β”œβ”€β”€ config.yml
β”‚ β”œβ”€β”€ CONTRIBUTING.md
β”‚ β”œβ”€β”€ FUNDING.yml
β”‚ β”œβ”€β”€ issue_label_bot.yaml
β”‚ β”œβ”€β”€ ISSUE_TEMPLATE
β”‚ β”‚ β”œβ”€β”€ 1-bug-report.md
β”‚ β”‚ β”œβ”€β”€ 2-failing-test.md
β”‚ β”‚ β”œβ”€β”€ 3-docs-bug.md
β”‚ β”‚ β”œβ”€β”€ 4-feature-request.md
β”‚ β”‚ β”œβ”€β”€ 5-enhancement-request.md
β”‚ β”‚ β”œβ”€β”€ 6-security-report.md
β”‚ β”‚ β”œβ”€β”€ 7-question-support.md
β”‚ β”‚ └── config.yml
β”‚ β”œβ”€β”€ ISSUE_TEMPLATE.md
β”‚ β”œβ”€β”€ pull_request_template.md
β”‚ β”œβ”€β”€ SECURITY.md
β”‚ β”œβ”€β”€ settings.yml
β”‚ └── SUPPORT.md
β”œβ”€β”€ .gitignore
β”œβ”€β”€ LICENSE
β”œβ”€β”€ MAKE_SCRIPT_GLOBAL.sh
└── README.md

2 directories, 25 files
```

---

## πŸ“ **Additional notes**

* The compressed PDF's will automatically replace your old and uncompressed ones.
* In case an error happens because there are multiple pdfs with the same name or simply the program doesn't know how to replace them, an error will be prompt and you will have to manually move the compressed pdf (which will be in the directory passed as an argument) to the desired directory.
* The cloned repository should not be removed as it contains the symbolic link which is globally executable. You can manually move the file and the .env file to your /bin/ folder if you wish.

---

Compress-PDFs was generated from *[Josee9988/project-template](https://github.com/Josee9988/project-template)* πŸ“š

---

## πŸ•΅οΈ Extra recommendations

* Always check the console output to check if any error happened and if so, you will have to manually move the non-moved compressed file to its location.

* Also, always perform a copy of the folder before using the script as it will remove the old PDFs, and it might cause some data loss if an error occurs.

---

## πŸŽ‰ Was the pdf compressor helpful? Help us raise these numbers up

[![Github followers](https://img.shields.io/github/followers/Josee9988.svg?style=social)](https://github.com/Josee9988)
[![Github stars](https://img.shields.io/github/stars/Josee9988/Compress-PDFs.svg?style=social)](https://github.com/Josee9988/Compress-PDFs/stargazers)
[![Github watchers](https://img.shields.io/github/watchers/Josee9988/Compress-PDFs.svg?style=social)](https://github.com/Josee9988/Compress-PDFs/watchers)
[![Github forks](https://img.shields.io/github/forks/Josee9988/Compress-PDFs.svg?style=social)](https://github.com/Josee9988/Compress-PDFs/network/members)
[![Sponsor](https://img.shields.io/static/v1?label=Sponsor&message=%E2%9D%A4&logo=github-sponsors&color=red&style=social)](https://github.com/sponsors/Josee9988)

Enjoy! πŸ˜ƒ

---

## βš–οΈπŸ“ **License**

See the license in the '**[LICENSE](LICENSE)**' file.

---

_Made with a lot of ❀️❀️ by **[@Josee9988](https://github.com/Josee9988)**_