Skip to main content

A modern YouTube video downloader with a beautiful PyQt5 interface

Project description

ViDownloader

ViDownloader Logo

License: MIT Python 3.9+ Status: Beta PyPI Version Platform: Windows & Linux Built with PyQt5 Powered by yt-dlp

[!WARNING] Heads up: This is currently in Beta phase. It works, but there might be rough edges and unexpected behavior. Your feedback will help shape the stable release.


What This Is

ViDownloader is a desktop application built with PyQt5 that simplifies downloading YouTube videos in bulk. While it uses yt-dlp under the hood for the actual downloading, the scraping and interface are completely custom-built.

This happens to be my first substantial open-source project, so please bear with me. it might do some dumb things, but I'm learning as I go. If something breaks or doesn't make sense, let me know and I'll do my best to fix it.


Quick Start

Install via pip (PyPI)

pip install vidownloader

Or from source

git clone https://github.com/farhaanaliii/vidownloader.git
cd vidownloader
pip install -e .

Launch the App

After installation, run:

vidownloader

Or, if you prefer:

python -m vidownloader

What You Can Download

Paste almost any YouTube URL and ViDownloader will figure out the rest:

  • Channel videoshttps://youtube.com/@channel/videos
  • Channel shortshttps://youtube.com/@channel/shorts
  • Playlist videoshttps://youtube.com/playlist?list=PLAYLIST_ID
  • Single videoshttps://youtube.com/watch?v=VIDEO_ID
  • Single shortshttps://youtube.com/shorts/VIDEO_ID

Just paste one or more links (one per line) and let the app handle the scraping and downloading.


How It Works

  1. Paste Links – Add YouTube URLs into the text area
  2. Scrape Metadata – Click Start to fetch video details using custom scraping logic
  3. Select Videos – Choose which videos you want from the list
  4. Download – Hit Download and let yt-dlp do its magic in the background

The interface sits on top of yt-dlp for reliable downloads, but all the scraping, queuing, and progress tracking happens within ViDownloader itself.


Configuration

Open Settings (top-right corner) to adjust:

Setting What It Does
Download Location Where your videos are saved
Export Location Where .viio list files are stored
File Naming Name files by title, video ID, or random string
Download Threads Simultaneous downloads (1–10 threads)

Export & Resume

Working with a large channel? Export your video list as a .viio file, close the app, and import it later to resume right where you left off. No need to re-scrape everything.


System Requirements

  • Python 3.9 or newer
  • PyQt5 (≥ 5.15.11)
  • yt-dlp (latest recommended)
  • curl_cffi
  • FFmpeg – Required by yt-dlp for video/audio processing (download)
  • JavaScript Runtime – yt-dlp needs a JS engine to handle some videos. Install one of:

Python dependencies install automatically via pip. You'll need to install FFmpeg and a JS runtime separately.

[!TIP] One-click installer coming soon! A standalone installer that bundles all dependencies is in development.


Building Executables

Want to build a standalone executable? Use the provided build scripts:

Windows:

.\build.bat

Linux:

./build.sh

These scripts will automatically:

  • Set up the virtual environment
  • Install dependencies
  • Compile Qt resources
  • Build the executable using Nuitka

Pre-built executables are also available for download:

  • Windows (x86/x64)
  • Linux (x64)

Check the Releases page for downloads.


Development & Contribution

This is my first major open-source project, so I'm sure there are plenty of areas to improve. If you find bugs, have feature ideas, or want to contribute code:

  1. Fork the repository
  2. Create a feature branch
  3. Submit a pull request

All contributions are welcome. just try to match the existing code style.


License

Released under the MIT License. Use it, modify it, share it.


Coming Soon

  • Format & quality selection – Pick 720p, 1080p, 4K, etc.
  • Advanced filtering – Search and filter video lists
  • Download history – Track your past downloads
  • Improved error handling – Making the app more resilient

TODO: If you're good with design, we could really use a better logo. The current one is... functional, but not pretty. Any takers?


Acknowledgment

While ViDownloader implements its own scraping logic, it relies on the excellent yt-dlp project for actual video downloading. Big thanks to the yt-dlp maintainers for their incredible work.


Author

Built by Farhan Ali – my first serious dive into open-source desktop apps. Be gentle.

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

vidownloader-1.0.0b0.tar.gz (689.6 kB view details)

Uploaded Source

Built Distribution

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

vidownloader-1.0.0b0-py3-none-any.whl (721.9 kB view details)

Uploaded Python 3

File details

Details for the file vidownloader-1.0.0b0.tar.gz.

File metadata

  • Download URL: vidownloader-1.0.0b0.tar.gz
  • Upload date:
  • Size: 689.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.1

File hashes

Hashes for vidownloader-1.0.0b0.tar.gz
Algorithm Hash digest
SHA256 f184483eb19c5fd3f01d9eb6082e84c3b147b702cc92e6763e9c644c4984d3e5
MD5 b48124287119bd0b4246f6c5de4b97bb
BLAKE2b-256 35bf62dfb86b105a46452f2ead51b1c287dc3060c48f328d5ac154091317927b

See more details on using hashes here.

File details

Details for the file vidownloader-1.0.0b0-py3-none-any.whl.

File metadata

  • Download URL: vidownloader-1.0.0b0-py3-none-any.whl
  • Upload date:
  • Size: 721.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.1

File hashes

Hashes for vidownloader-1.0.0b0-py3-none-any.whl
Algorithm Hash digest
SHA256 2dbc3ed93e88da5019d5906003ed9a3cc72e5e7a2fbc5cc5830183ef8b4b45a2
MD5 c447883eed977ae912333b263a7f946c
BLAKE2b-256 3b2ca6adad780eb334f9ad5c648c7f289bd98bee51e0f5dd0fc2c537aaa6dc23

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