A lightweight, fast, and safe batch renaming and filesystem organization tool.
reny was originally created as the renamer component inside the larger batchmp (Batch Media Processing) suite. It was spun off into its own standalone package to provide for an ultra-lightweight, safe, pure-filesystem organizing tool without FFmpeg / Mutagen media dependencies.
If you need advanced media operations (like denoising, cover-art extraction, or format transcoding), check out the original batchmp project. If you just need to safely organize your files with surgical precision, reny is all you need.
You can safely install reny from the PyPI package using pipx:
pipx install reny(Note: If this is your first time using pipx, you may need to run pipx ensurepath once to ensure the installed tools are available in your terminal).
- Virtual Views: Preview how a directory structure would look when reorganised by type, size, or date without moving or changing anything
- Indexing: Multi-level indexing across nested directories, supporting multiple indexing schemes
- Padding: Automatically pad existing numbers in filenames with leading zeros to fix sorting orders
- Flattening: Safely collapse nested directory structures into a single folder
- Regex Replacement: Powerful batch renaming using standard regular expressions
- Dry-Run by Default:
renywill always visualize targeted changes and ask for confirmation before it ever touches your files
Print current directory structure:
reny(Without arguments, reny defaults to the print command)
Add a sequential index to all .txt files recursively:
reny -r -in '*.txt' indexLimit Recursion Depth (-el):
Use -el (end level) to control exactly how deep reny recurses. For example, to add an index only to files inside immediate subdirectories (depth 1), while ignoring deeper nested folders:
reny -r -el 1 indexPad existing numbers with leading zeros (e.g., 2 kms.png becomes 02 kms.png):
reny pad -md 2Regex Replace: Change spaces to underscores in all filenames:
reny replace -fs ' ' -rs '_'Flattening nested directories: Collapse all sub-directories and bring their files up to the current folder level:
reny flattenOrganize by File Type:
Move files into sub-directories grouped by their file extension (e.g., png/, pdf/):
reny organize -b typeVirtual Views (Dry-Run Preview): Preview how files would look if organized by year and month, without actually moving any files on your drive:
reny print -b date --date-format "%Y/%m"Virtual view by date:
~/Downloads
|- 2025/
|- 01/
|- document.pdf
|- 02/
|- image.png
A safe, two-step workflow to tame a chaotic downloads folder by grouping files by their extension and sorting them by size to see what's eating up your disk space.
Step 1: Preview the cleanup with size statistics (Shows you the largest file categories first, without moving any files)
reny -s sd print -b type -ssStep 2: Commit the organization (Actually moves the files into their respective subdirectories)
reny organize -b typeAlthough reny is a standalone project, its core organizing logic is inherited directly from batchmp. You can find detailed tutorials and deep-dives on how to master its capabilities in the original blog posts:
- Renamer Organize & Virtual Views – Highly recommended reading for mastering virtual directory views
- BatchMP Tools Tutorial, Part II: renaming files with renamer
- Practical BatchMP Series
Run reny --help to see all available filesystem operations!
To set up the project for development:
- Clone the repository and navigate into it:
git clone https://github.com/akpw/reny.git cd reny - Create and activate a virtual environment:
python3 -m venv .venv source .venv/bin/activate - Install the project in editable mode along with testing dependencies:
pip install -e ".[test]"
The project uses pytest for its test suite. Because reny performs real filesystem operations, the tests are designed to dynamically create and clean up safe temporary sandbox folders during execution.
To run the full test suite:
pytest -v --tb=short tests/To run a specific test file:
pytest tests/fs/test_fs_organize.py