Skip to main content

A lightweight, powerful batch renaming and filesystem organizing CLI tool.

Project description

Reny

A lightweight, fast, and safe batch renaming and filesystem organization tool.

Background

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 a 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.

Installation

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).

Features

  • Dry-Run by Default: reny will always visualize targeted changes and ask for confirmation before it ever touches your files
  • Virtual Views: Preview how a directory structure would look when reorganised by type, size, or date without moving or changing anything
  • Filtering & Leveling: Precise targeting using include/exclude patterns and recursion control with end_level / start_level parameters
  • 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

Examples

Basic Operations

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' index

Limit 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 index

Pad existing numbers with leading zeros (e.g., 2 kms.png becomes 02 kms.png):

reny pad -md 2

Regex Replace: Change spaces to underscores in all filenames:

reny replace -fs ' ' -rs '_'

Advanced Operations & Virtual Views

Flattening nested directories: Collapse all sub-directories and bring their files up to the current folder level:

reny flatten

Organize by File Type: Move files into sub-directories grouped by their file extension (e.g., png/, pdf/):

reny organize -b type

Virtual 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

Ignore Files (.renyignore)

By default, reny will automatically detect a .renyignore file in your target directory (falling back to a global ~/.renyignore if none is found) to cleanly exclude specific directories from processing.

You can also explicitly pass any file, like a standard .gitignore, to automatically parse and exclude those paths from the output:

reny -r -el 2 -ig .gitignore
~/Desktop/_Dev/reny
  |- LICENSE
  |- pyproject.toml
  |- README.md
  |- setup.py
  |->/reny
    |- __init__.py
    |->/cli
      |- __init__.py
      |-/base
      |-/renamer
    |->/commons
      |- __init__.py
      |- chainedhandler.py
      |- descriptors.py
      |- progressbar.py
      |- taskprocessor.py
      |- utils.py
    |->/fstools
      |- __init__.py
      |- dirtools.py
      |- fsutils.py
      |- rename.py
      |- virtual_organizer.py
      |- walker.py
      |-/builders
  |->/tests
    |- __init__.py
    |->/base
      |- __init__.py
      |- test_base.py
    |->/commons
      |- __init__.py
      |- test_commons.py
      |- test_ignore.py
    |->/fs
      |- __init__.py
      |- test_fs_base.py
      |- test_fs_organize.py
      |- test_fsutils.py
      |-/data
28 files, 12 folders

Real-World Scenario: Downloads Cleanup

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 -ss

Step 2: Commit the organization (Actually moves the files into their respective subdirectories)

reny organize -b type

Documentation & Tutorials

Although 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:

Usage

Run reny --help to see all available filesystem operations!

Development

To set up the project for development:

  1. Clone the repository and navigate into it:
    git clone https://github.com/akpw/reny.git
    cd reny
    
  2. Create and activate a virtual environment:
    python3 -m venv .venv
    source .venv/bin/activate
    
  3. Install the project in editable mode along with testing dependencies:
    pip install -e ".[test]"
    

Running Tests

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

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

reny-1.0.6.tar.gz (49.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

reny-1.0.6-py3-none-any.whl (62.2 kB view details)

Uploaded Python 3

File details

Details for the file reny-1.0.6.tar.gz.

File metadata

  • Download URL: reny-1.0.6.tar.gz
  • Upload date:
  • Size: 49.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.6

File hashes

Hashes for reny-1.0.6.tar.gz
Algorithm Hash digest
SHA256 a1dfc3bf43543b2b281fd3aee30a8edbc4a20d69d2854c9cb8285ee8c3be16f7
MD5 289183df387ea86c4f290317fac93782
BLAKE2b-256 aa71dcc5694f7a88c81a86a522ecc5b18e82dfd7a1c8598b58767de4a922e5de

See more details on using hashes here.

File details

Details for the file reny-1.0.6-py3-none-any.whl.

File metadata

  • Download URL: reny-1.0.6-py3-none-any.whl
  • Upload date:
  • Size: 62.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.6

File hashes

Hashes for reny-1.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 9e88666b617de8ba3c6735abc73d38d41e806e8e8da9883660ec7cc088ec7748
MD5 58e18c7a9a94730760e3c3ecb7d9bf19
BLAKE2b-256 7b2f7a6fb68e61f81be986e24e68795a02268ece8f994316f2db6529f22fae2e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page