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

https://github.com/jamjamjon/renify

A simple cli tool for batch renaming files and folders, written in Rust.
https://github.com/jamjamjon/renify

rename rename-files renamer

Last synced: 5 months ago
JSON representation

A simple cli tool for batch renaming files and folders, written in Rust.

Awesome Lists containing this project

README

          

# Renify
A simple cli tool for batch renaming files and folders, written in Rust.

- πŸš€ written in Rust, fast.
- πŸŽ‰ Available on PyPi, install via `pip`.
- 🧩 `Windows` `Linux` `MacOS` support.
- πŸ“” `files` and `folders` support.
- 🎁 **7** renaming methods provided.
- ⚠️ `symlinks` are `unsupported` for now!

![Example GIF](assets/demo.gif)

# Installation
```
pip install renify
# or
cargo install renify
```

# Usage
### Renaming - 重命名
For those new to Renify, consider using the following code for **interactive mode**:
```bash
renify -i
```

Or you can use:
```bash
renify -i --target file --method znum --nbits 5 --recursive false --start 1 -y
```

### Rolling back - ι€€ε›žδΈŠδΈ€ζ¬‘ζ“δ½œ
You can revert to the previous state of the modifications by using:
```bash
renify -i . --roll
```

### Help & options
You can get help from:
```bash
renify --help
```

# Methods provided
- [x] **random:** Sample a u8, uniformly distributed over ASCII letters and numbers: a-z, A-Z and 0-9. `9AFoh, wGRLC, knj9y, ...`
- [x] **uuid:** Uuid4. `de2662a9-fb02-4686-b556-0aca36c0e087`
- [x] **time:** Local time now. `2023-03-04-22-26-42-222655555`
- [x] **num:** Numbers start from `--start` (1 by default). `1, 2, 3, ...`
- [x] **znum:** Numbers with left zero padding start from `--start` (1 by default). `001, 002, 003, ...`
- [x] **prefix:** Add a prefix string to the file stem, along with a delimiter. `X.jpg => [--with][--delimiter]X.jpg`
- [x] **append:** Append a delimiter and a string after the file stem. `X.jpg => X[--delimiter][--with].jpg`

# Note that
Renify will set `--indiscriminate false` to make sure that the file stems stay consistent. This means that if you have files with the same stems in the same folder, they'll still look the same even after you rename them. Certainly, you can use `--indiscriminate` to treat each file as an independent entity without considering its relationship with other files.