A Python library for downloading videos from UW Panopto
Project description
UW Panopto Downloader
A Python tool for downloading videos from UW Panopto and optionally converting them to audio format.
Features
- Interactive browser-based login to access your Panopto content
- Extract video links from Panopto course pages
- Concurrent downloading of multiple videos
- Video to audio conversion (MP4 to MP3)
- User-friendly command line interface with rich formatting
- Configurable settings saved between sessions
Installation
# From PyPI
pip install uw-panopto-downloader
# From source
git clone https://github.com/elimelt/uw-panopto-downloader.git
cd uw-panopto-downloader
pip install -e .
Requirements
- Python 3.11 or higher
- FFmpeg (for video downloads and conversion)
- Chrome or Chromium browser (for Selenium)
Usage
Command Line Interface
The package provides a command-line tool uwpd with several subcommands:
# Show help
uwpd --help
# Download videos
uwpd download [OPTIONS]
# Convert videos to audio
uwpd convert [INPUT] [OPTIONS]
# View or update configuration
uwpd config [OPTIONS]
# Show version
uwpd version
Download Command
# Start an interactive download session
uwpd download
# Specify a starting URL
uwpd download --url "https://panopto.uw.edu/your-course-page"
# Set output directory
uwpd download --output "path/to/downloads"
# Set number of concurrent downloads
uwpd download --workers 5
# Run in headless mode (no browser window)
uwpd download --headless
Convert Command
# Convert a single video
uwpd convert video.mp4
# Convert with output path
uwpd convert video.mp4 --output audio.mp3
# Convert a directory of videos
uwpd convert videos_dir/ --output audio_dir/
# Set audio bitrate
uwpd convert video.mp4 --bitrate 320k
# Set number of FFmpeg threads
uwpd convert video.mp4 --threads 4
Config Command
# Show current configuration
uwpd config --show
# Update configuration
uwpd config --download-dir "path/to/downloads" --max-workers 4
Python API
You can also use the package programmatically:
from uw_panopto_downloader.core import BrowserSession, PanoptoDownloader, VideoConverter
# Initialize a browser session
browser = BrowserSession(headless=False)
browser.manual_login("https://panopto.uw.edu/your-course-page")
# Download videos
downloader = PanoptoDownloader(browser, max_workers=3)
video_links = browser.extract_links()
downloader.download_videos(video_links, "downloads")
# Convert videos to audio
converter = VideoConverter(bitrate="192k")
converter.convert_directory("downloads", "audio")
Configuration
The configuration is stored in ~/.uw-panopto-downloader/config.json and includes:
download_dir: Default download directorymax_workers: Maximum number of concurrent downloadsheadless: Whether to run the browser in headless modeaudio_bitrate: Default audio bitrate for conversionffmpeg_threads: Default number of FFmpeg threads
License
This project is licensed under the MIT License - see the LICENSE file for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file uw_panopto_downloader-1.0.8.tar.gz.
File metadata
- Download URL: uw_panopto_downloader-1.0.8.tar.gz
- Upload date:
- Size: 20.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d87770028802d22b69569b38cdbe8d946ece3be5ee50177ce3d7d525ccf5314e
|
|
| MD5 |
5a92ace76a784e73ac3d06202ca533e0
|
|
| BLAKE2b-256 |
7aae270c044d678bfd1f69fc46e15ada3c03e3a3ebc3f0821f112e9c0a3eba48
|
File details
Details for the file uw_panopto_downloader-1.0.8-py3-none-any.whl.
File metadata
- Download URL: uw_panopto_downloader-1.0.8-py3-none-any.whl
- Upload date:
- Size: 25.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a96dcfca24c92ad5557c5fec349bcfe1e161510904a912ca68fd2aba0c4ca529
|
|
| MD5 |
2c03278ac0b46b791618408c5b19500f
|
|
| BLAKE2b-256 |
987d263940d4c5096a84d117a6e7ca2994de836496378078d9ee2495e3dbe65e
|