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

https://github.com/mfm-347/ren.py

RenPy is a Python CLI tool for renaming files efficiently.
https://github.com/mfm-347/ren.py

automatic automation contributions-welcome mfm3478 opensource py-lib python renamer renpy

Last synced: 4 months ago
JSON representation

RenPy is a Python CLI tool for renaming files efficiently.

Awesome Lists containing this project

README

          

# **RenPy: CLI & Library for Auto Renaming** ๐Ÿš€

RenPy is a **Python library and CLI tool** designed to **automate file renaming** in a given directory. It sequentially renames files using a specified **base name**, appending a numeric index while preserving the original file extension.

## **๐Ÿ“Œ Features**

| Feature | Availability | Description |
| ------------------- | ------------ | ----------------------------------------------------------------------------- |
| **Batch Rename** | โœ” | Rename multiple files at once with a custom prefix. |
| **Sorting Options** | โœ” | Rename files in alphabetical, newest, or oldest order. |
| **Simulation Mode** | โœ” | Preview renaming changes without modifying files. No actual changes are made. |
| **Library Support** | โœ” | Use RenPy as a module in your Python scripts for automation. |
| **Cross-Platform** | โœ” | Works seamlessly on Windows, macOS, and Linux. |

## **๐Ÿ› ๏ธ Prerequisites**

- **Python 3.x** installed
- Basic knowledge of **command-line usage**

### **๐Ÿ“ฆ Required Python Packages**

RenPy requires the following package(s):

- `pyfiglet` (for CLI banner text)

To install dependencies, run:

```sh
pip install -r requirements.txt # Use pip3 on macOS
```

## **โšก Installation**

### **๐Ÿ”น Install via Pip**

To install RenPy as a library:

```sh
pip install renpy
```

### **๐Ÿ”น Install from Source**

To install and run the tool from the source code:

```sh
(git clone https://github.com/MFM-347/Ren.py.git
cd Ren.py
pip install .
```

## **๐Ÿ’ป CLI Usage**

### **๐Ÿ“Œ Run the CLI**

```sh
renpy [-r ] [-s]
```

### **Example**

Rename files inside `C:\Users\YourName\Documents\Folder`, using "File" as the base name:

```sh
renpy "File" C:\Users\YourName\Documents\Folder
```

### **๐Ÿ“‚ Given Directory (`C:\Docs`)**

```
report.docx
notes.txt
summary.pdf
```

### **๐Ÿท๏ธ Renaming Command**

```sh
renpy "Document" C:\Docs -r alphabet
```

### **๐Ÿ“ Output**

```
Document-1.docx
Document-2.pdf
Document-3.txt
```

## **โš™๏ธ Command-Line Options**

| Option | Description |
| --------------------- | -------------------------------------------- |
| `` | Prefix for renamed files. |
| `` | Path to folder containing the files. |
| `-r, --order ` | Sorting order before renaming: |
| | - `alphabet` โ†’ A-Z order |
| | - `new` โ†’ Newest to oldest |
| | - `old` โ†’ Oldest to newest (default) |
| `-s, --simulate` | Run a **simulation** without renaming files. |
| `--case-sensitive` | Sorts filenames in case-sensitive mode. |
| `--debug` | Enables debug logging. |

## **๐Ÿ“ฆ Using RenPy as a Library**

### **๐Ÿ”น Installed Library Usage**

If you have installed RenPy via `pip`, you can use it in your Python scripts as follows:

```python
from renpy import renFn
from pathlib import Path

directory = Path("C:/Users/YourName/Documents/Folder")
renFn(base_name="Document", directory=directory, order="alphabet", simulate=False, case_sensitive=False)
```

### **๐Ÿ”น Source Code Usage**

If running directly from the cloned source repository:

```python
from renpy import renFn
from pathlib import Path

directory = Path("C:/Users/YourName/Documents/Folder")
renFn(base_name="Document", directory=directory, order="alphabet", simulate=False, case_sensitive=False)
```

### **Sorting Files Only**

If you only need to **get sorted files** without renaming:

```python
from renpy import sortFn
from pathlib import Path

directory = Path("/path/to/files")
sorted_files = sortFn(directory, order="new", case_sensitive=True)
print(sorted_files)
```

### **Handling Errors Gracefully**

You can wrap it in a try-except block:

```python
try:
renFn("Example", Path("/home/user/files"), "old", False, False)
except Exception as e:
print(f"An error occurred: {e}")
```

## **๐Ÿงช Running Tests (For Source Code Only)**

Run all tests:

```sh
python -m unittest discover tests
```

## Future Plans

- Add option to rename only specific file type.
- Add Graphic User Interface (GUI).

## **๐Ÿค Contributing**

We welcome contributions! Please check the [CONTRIBUTING.md](https://github.com/MFM-347/Ren.py/blob/main/CONTRIBUTING.md) for guidelines.

## **๐Ÿ‘จโ€๐Ÿ’ป Credits**

Created and maintained by [MFM-347](https://github.com/MFM-347).

## **๐Ÿ“œ License**

This project is licensed under the **MIT License**.

[![License MIT](https://img.shields.io/badge/License-MIT-green.svg)](https://github.com/MFM-347/Ren.py/LICENSE)