Batch process (resize, rotate, remove GPS, add border, set transparency, auto do all) image files (HEIC, JPG, PNG)
Project description
batch_img
Batch processing (resize, rotate, remove GPS, add border, set transparency, auto do all) image files (HEIC, JPG, PNG) by utilizing Pillow / PIL library. Resize, remove GPS, rotate, set transparency, add border to a single image file or all image files in a folder / dir. Tested on macOS and Windows.
Installation
One-time Setup
Install the Astral's uv tool one-time to
prepare for all Python tools and packages installation. Install the Astral's
uv by its standalone installers:
# On macOS and Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
uv venv
source .venv/bin/activate
# On Windows (PowerShell)
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
$env:Path = "C:\Users\{your_user_name}\.local\bin:$env:Path"
uv venv
.venv\Scripts\activate
Install the batch_img tool
Install the batch_img tool from PyPI by the Astral's
uv command:
uv pip install --upgrade batch_img
Usage
Sample command line usage:
✗ batch_img --version
0.2.5
✗ batch_img auto ~/Documents
Resize to 1920-pixel max length. Remove GPS location info. Add 5-pixel width black color border.
...
Auto processed 8/8 files
✅ Processed the image file(s)
Help
Top level commands help:
✗ batch_img --help
Usage: batch_img [OPTIONS] COMMAND [ARGS]...
Options:
--update Update the tool to the latest version.
--version Show the tool's version.
--help Show this message and exit.
Commands:
auto Auto process (resize to 1920, remove GPS, add border)...
border Add internal border to image file(s), not expand the size.
no-gps Remove GPS location info in image file(s).
resize Resize image file(s).
rotate Rotate image file(s).
transparent Set transparency on image file(s).
The auto sub-command CLI options:
✗ batch_img auto --help
Usage: batch_img auto [OPTIONS] SRC_PATH
Auto process (resize to 1920, remove GPS, add border) image file(s).
Options:
-ar, --auto_rotate Auto-rotate image (experimental)
-o, --output TEXT Output file path. If not specified, replace the input
file. [default: ""]
--help Show this message and exit.
The border sub-command CLI options:
✗ batch_img border --help
Usage: batch_img border [OPTIONS] SRC_PATH
Add internal border to image file(s), not expand the size.
Options:
-bw, --border_width INTEGER RANGE
Add border to image file(s) with the
border_width. 0 - no border. [default: 5;
0<=x<=30]
-bc, --border_color TEXT Add border to image file(s) with the
border_color string. [default: gray]
-o, --output TEXT Output file path. If not specified, replace
the input file. [default: ""]
--help Show this message and exit.
The no-gps sub-command CLI options:
✗ batch_img no-gps --help
Usage: batch_img no-gps [OPTIONS] SRC_PATH
Remove GPS location info in image file(s).
Options:
-o, --output TEXT Output file path. If not specified, replace the input
file. [default: ""]
--help Show this message and exit.
The resize sub-command CLI options:
✗ batch_img resize --help
Usage: batch_img resize [OPTIONS] SRC_PATH
Resize image file(s).
Options:
-l, --length INTEGER RANGE Resize image file(s) on original aspect ratio to
the max side length. 0 - no resize. [default:
0; x>=0]
-o, --output TEXT Output file path. If not specified, replace the
input file. [default: ""]
--help Show this message and exit.
The rotate sub-command CLI options:
✗ batch_img rotate --help
Usage: batch_img rotate [OPTIONS] SRC_PATH
Rotate image file(s).
Options:
-a, --angle [0|90|180|270] Rotate image file(s) to the clockwise angle. 0 -
no rotate. [default: 0]
-o, --output TEXT Output file path. If not specified, replace the
input file. [default: ""]
--help Show this message and exit.
The transparent sub-command CLI options:
✗ batch_img transparent --help
Usage: batch_img transparent [OPTIONS] SRC_PATH
Set transparency on image file(s).
Options:
-o, --output TEXT Output file path. If not specified, replace
the input file. If the input file is JPEG,
it will be saved as PNG file because JPEG
does not support transparency [default: ""]
-t, --transparency INTEGER RANGE
Set transparency on image file(s). 0 - fully
transparent, 255 - completely opaque.
[default: 127; 0<=x<=255]
-w, --white Make white pixels fully transparent.
--help Show this message and exit.
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 batch_img-0.2.5.tar.gz.
File metadata
- Download URL: batch_img-0.2.5.tar.gz
- Upload date:
- Size: 18.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b7a2588d3d46dddee0da5de3466d997b76f4b828c99aff4682dfb30b6db70522
|
|
| MD5 |
59397e4ef063e022fc1e8eb10d34776c
|
|
| BLAKE2b-256 |
1d952018f7dc3a4ca9676524ab0a3a843a7de279adaa65e4e9afdc99a733b223
|
File details
Details for the file batch_img-0.2.5-py3-none-any.whl.
File metadata
- Download URL: batch_img-0.2.5-py3-none-any.whl
- Upload date:
- Size: 23.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
71e259821b5ebc63a21bb0c439e2c0d24e65254cea97930efad51359e7ddfd9d
|
|
| MD5 |
0dadb2451891b8237af94333a1ae22bf
|
|
| BLAKE2b-256 |
3db659bf821a10a743aba5c64eecbc42e804cb188f78205e3ad2f92cae13438b
|