A simple terminal YouTube client for searching and watching videos using yt-dlp and mpv.
- Overview
- Features
- Who is this Project for?
- Prerequisites
- Installation
- Usage
- Configuration
- Roadmap
- Star History
- Contributing
GopherTube is a tui based youtube client. It scrapes and parses the youtube website to get the metadate and uses mpv to play videos. The ui is built with bubbletea, and is keyboard driven.
Screenshots
main menu
searching for videos
video plays in mpv
Demo Video
▶ Watch the demo video
- Fast YouTube search (scrapes YouTube directly, no API key needed)
- Play videos with mpv
- Minimal terminal UI (fzf)
- Keyboard navigation (arrows, Enter, Tab, Esc)
- TOML config
- Download videos with quality selection (yt-dlp)
- Downloads menu: browse and play downloaded videos
- Thumbnail preview in downloads menu
- this project is for everyone who enjoys tuis,
- anyone who wants to watch videos while using low system resources. for example if you have an older or lowspec machine that struggles to run youtube in full web browser this app might help you cut down recourse usage.
This assumes you have mpv and yt-dlp installed in your system. if not refer to this to install them first.
mpv installation yt-dlp installation
curl -sSL https://raw.githubusercontent.com/KrishnaSSH/GopherTube/main/install.sh | bashyay -S gophertubeyay -S gophertube-bin - the binary version of this package is not maintained by me contact the maintainer for issues
- Start the app:
gophertube - Select between Search Youtube, Search Downloads, Settings, Quit. and press enter.
- Use up down keys or j/k to move, Enter to play, Tab to load more, Esc to go back and ctrl-c to close
- search something and mpv opens to play selected video.
Create ~/.config/gophertube/gophertube.toml:
search_limit = 30
quality = "1080p" # default: 1080p (options: 1080p, 720p, 480p, 360p, Audio)
downloads_path = "/home/$USER/Videos/GopherTube" # where to save downloads
theme = "Minimal" # default: Minimal (options: Minimal, Gopher, Gruvbox, etc)| Key | Type | Default | Description |
|---|---|---|---|
| search_limit | int | 30 | Max results to fetch per page/load more. |
| quality | string | "1080p" | Preferred quality or Audio for audio-only. |
| downloads_path | string | "$HOME/Videos/GopherTube" | Directory to save downloads. |
| theme | string | "Minimal" | Default application theme. |
- thumbnail support in the bubbletea rewrite
If you find this project useful, consider supporting its development with crypto:
bc1q78ymwmf33vr33ly8rpej7cqvr6cljjcdjf3g6p |
|
ltc1qsfp4mdwwk3nppj278ayphqmkyf90xvysxp3des |
|
0x6f786f482DDa360679791D90B7C8337655dC2199 |
PRs and issues welcome.
See CONTRIBUTING.md for guidelines.

