https://github.com/benexl/viu
Your browser anime experience from the terminal
https://github.com/benexl/viu
anilist anime anime-scraper api application cli click fastanime python rich scraping
Last synced: about 2 months ago
JSON representation
Your browser anime experience from the terminal
- Host: GitHub
- URL: https://github.com/benexl/viu
- Owner: Benexl
- License: unlicense
- Created: 2024-05-27T15:56:11.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2025-08-16T13:58:31.000Z (about 2 months ago)
- Last Synced: 2025-08-16T15:04:55.448Z (about 2 months ago)
- Topics: anilist, anime, anime-scraper, api, application, cli, click, fastanime, python, rich, scraping
- Language: Python
- Homepage:
- Size: 58.6 MB
- Stars: 815
- Watchers: 4
- Forks: 45
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
Viu
Your browser anime experience, from the terminal.
[](https://pypi.org/project/viu_cli/)
[](https://pypi.org/project/viu_cli/)
[](https://github.com/Benexl/Viu/actions)
[](https://discord.gg/HBEmAwvbHV)
[](https://github.com/Benexl/Viu/issues)
[](https://github.com/Benexl/Viu/blob/master/LICENSE)## Core Features
* 📺 **Interactive TUI:** Browse, search, and manage your AniList library in a rich terminal interface powered by `fzf`, `rofi`, or a built-in selector.
* ⚡ **Powerful Search:** Filter the entire AniList database with over 20 different criteria, including genres, tags, year, status, and score.
* đź’ľ **Local Registry:** Maintain a fast, local database of your anime for offline access, detailed stats, and robust data management.
* ⚙️ **Background Downloader:** Queue episodes for download and let a persistent background worker handle the rest.
* 📜 **Scriptable CLI:** Automate streaming and downloading with powerful, non-interactive commands perfect for scripting.
* 🔧 **Highly Customizable:** Tailor every aspect—from UI colors and providers to playback behavior—via a simple, well-documented configuration file.
* 🔌 **Extensible Architecture:** Easily add new providers, media players, and UI selectors to fit your workflow.## Installation
Viu runs on any platform with Python 3.10+, including Windows, macOS, Linux, and Android (via Termux).
### Prerequisites
For the best experience, please install these external tools:
* **Required for Streaming:**
* [**mpv**](https://mpv.io/installation/) - The primary and recommended media player.
* **Recommended for UI & Previews:**
* [**fzf**](https://github.com/junegunn/fzf) - For the best fuzzy-finder interface.
* [**chafa**](https://github.com/hpjansson/chafa) or [**kitty's icat**](https://sw.kovidgoyal.net/kitty/kittens/icat/) - For image previews in the terminal.
* **Recommended for Downloads & Advanced Features:**
* [**ffmpeg**](https://www.ffmpeg.org/) - Required for downloading HLS streams and merging subtitles.
* [**webtorrent-cli**](https://github.com/webtorrent/webtorrent-cli) - For streaming torrents directly.### Recommended Installation (uv)
The best way to install Viu is with [**uv**](https://github.com/astral-sh/uv), a lightning-fast Python package manager.
```bash
# Install with all optional features for the full experience
uv tool install "viu_cli[standard]"# Or, pick and choose the extras you need:
uv tool install viu_cli # Core functionality only
uv tool install "viu_cli[download]" # For advanced downloading with yt-dlp
uv tool install "viu_cli[discord]" # For Discord Rich Presence
uv tool install "viu_cli[notifications]" # For desktop notifications
```### Other Installation Methods
Platform-Specific and Alternative Installers
#### Nix / NixOS
```bash
nix profile install github:Benexl/viu
```#### Arch Linux (AUR)
Use an AUR helper like `yay` or `paru`.
```bash
# Stable version (recommended)
yay -S viu# Git version (latest commit)
yay -S viu-git
```#### Using pipx (for isolated environments)
```bash
pipx install "viu_cli[standard]"
```
#### Using pip
```bash
pip install "viu_cli[standard]"
```Building from Source
Requires [Git](https://git-scm.com/), [Python 3.10+](https://www.python.org/), and [uv](https://astral.sh/blog/uv).
```bash
git clone https://github.com/Benexl/Viu.git --depth 1
cd Viu
uv tool install .
viu --version
```> [!TIP]
> Enable shell completions for a much better experience by running `viu completions` and following the on-screen instructions for your shell.## Getting Started: Quick Start
Get up and running in three simple steps:
1. **Authenticate with AniList:**
```bash
viu anilist auth
```
This will open your browser. Authorize the app and paste the obtained token back into the terminal.2. **Launch the Interactive TUI:**
```bash
viu anilist
```3. **Browse & Play:** Use your arrow keys to navigate the menus, select an anime, and choose an episode to stream instantly.
## Usage Guide
### The Interactive TUI (`viu anilist`)
This is the main, user-friendly way to use Viu. It provides a rich terminal experience where you can:
* Browse trending, popular, and seasonal anime.
* Manage your personal lists (Watching, Completed, Paused, etc.).
* Search for any anime in the AniList database.
* View detailed information, characters, recommendations, reviews, and airing schedules.
* Stream or download episodes directly from the menus.### Powerful Searching (`viu anilist search`)
Filter the entire AniList database with powerful command-line flags.
```bash
# Search for anime from 2024, sorted by popularity, that is releasing and not on your list
viu anilist search -y 2024 -s POPULARITY_DESC --status RELEASING --not-on-list# Find the most popular movies with the "Fantasy" genre
viu anilist search -g Fantasy -f MOVIE -s POPULARITY_DESC# Dump search results as JSON instead of launching the TUI
viu anilist search -t "Demon Slayer" --dump-json
```### Background Downloads (`viu queue` & `worker`)
Viu includes a robust background downloading system.
1. **Add episodes to the queue:**
```bash
# Add episodes 1-12 of Jujutsu Kaisen to the download queue
viu queue add -t "Jujutsu Kaisen" -r "0:12"
```
2. **Start the worker process:**
```bash
# Run the worker in the foreground (press Ctrl+C to stop)
viu worker# Or run it as a background process
viu worker &
```The worker will now process the queue, download your episodes, and check for notifications.### Scriptable Commands (`download` & `search`)
These commands are designed for automation and quick, non-interactive tasks.
#### `download` Examples
```bash
# Download the latest 5 episodes of One Piece
viu download -t "One Piece" -r "-5"# Download episodes 1 to 24, merge subtitles, and clean up original files
viu download -t "Jujutsu Kaisen" -r "0:24" --merge --clean
```#### `search` (Binging) Examples
```bash
# Start binging an anime from the first episode
viu search -t "Attack on Titan" -r ":"# Watch the latest episode directly
viu search -t "My Hero Academia" -r "-1"
```### Local Data Management (`viu registry`)
Viu maintains a local database of your anime for offline access and enhanced performance.
* `registry sync`: Synchronize your local data with your remote AniList account.
* `registry stats`: Show detailed statistics about your viewing habits.
* `registry backup`: Create a compressed backup of your entire registry.
* `registry restore`: Restore your data from a backup file.
* `registry export/import`: Export/import your data to JSON/CSV for use in other applications.
* `registry clean`: Clean up orphaned or invalid entries from your local database.## Configuration
Viu is highly customizable. A default configuration file with detailed comments is created on the first run.
* **Find your config file:** `viu config --path`
* **Edit in your default editor:** `viu config`
* **Use the interactive wizard:** `viu config --interactive`Most settings in the config file can be temporarily overridden with command-line flags (e.g., `viu --provider animepahe anilist`).
Default Configuration (`config.ini`) Explained
```ini
# [general] Section: Controls overall application behavior.
[general]
provider = allanime ; The default anime provider (allanime, animepahe).
selector = fzf ; The interactive UI tool (fzf, rofi, default).
preview = full ; Preview type in selectors (full, text, image, none).
image_renderer = icat ; Tool for terminal image previews (icat, chafa).
icons = True ; Display emoji icons in the UI.
auto_select_anime_result = True ; Automatically select the best search match.
...# [stream] Section: Controls playback and streaming.
[stream]
player = mpv ; The media player to use (mpv, vlc).
quality = 1080 ; Preferred stream quality (1080, 720, 480, 360).
translation_type = sub ; Preferred audio/subtitle type (sub, dub).
auto_next = False ; Automatically play the next episode.
continue_from_watch_history = True ; Resume playback from where you left off.
use_ipc = True ; Enable in-player controls via MPV's IPC.
...# [downloads] Section: Controls the downloader.
[downloads]
downloader = auto ; Downloader to use (auto, default, yt-dlp).
downloads_dir = ... ; Directory to save downloaded anime.
max_concurrent_downloads = 3 ; Number of parallel downloads in the worker.
merge_subtitles = True ; Automatically merge subtitles into the video file.
cleanup_after_merge = True ; Delete original files after merging.
...# [worker] Section: Controls the background worker process.
[worker]
enabled = True
notification_check_interval = 15 ; How often to check for new episodes (minutes).
download_check_interval = 5 ; How often to process the download queue (minutes).
...
```## Advanced Features
### MPV IPC Integration
When `use_ipc = True` is set in your config, Viu provides powerful in-player controls without needing to close MPV.
**Key Bindings:**
* `Shift+N`: Play the next episode.
* `Shift+P`: Play the previous episode.
* `Shift+R`: Reload the current episode.
* `Shift+A`: Toggle auto-play for the next episode.
* `Shift+T`: Toggle between `dub` and `sub`.**Script Messages (For MPV Console):**
* `script-message select-episode `: Jump to a specific episode.
* `script-message select-server `: Switch to a different streaming server.### Running as a Service (Linux/systemd)
You can run the background worker as a systemd service for persistence.
1. Create a service file at `~/.config/systemd/user/viu-worker.service`:
```ini
[Unit]
Description=Viu Background Worker
After=network-online.target[Service]
Type=simple
ExecStart=/path/to/your/viu worker --log
Restart=always
RestartSec=30[Install]
WantedBy=default.target
```
*Replace `/path/to/your/viu` with the output of `which viu`.*2. Enable and start the service:
```bash
systemctl --user daemon-reload
systemctl --user enable --now viu-worker.service
```## Contributing
Contributions are welcome! Whether it's reporting a bug, proposing a feature, or writing code, your help is appreciated. Please read our [**Contributing Guidelines**](CONTRIBUTIONS.md) to get started.
## Disclaimer
> [!IMPORTANT]
> This project scrapes public-facing websites. The developer(s) of this application have no affiliation with these content providers. This application hosts zero content and is intended for educational and personal use only. Use at your own risk.
>
> [**Read the Full Disclaimer**](DISCLAIMER.md)