youtube-tools
npx skills add https://github.com/casper-studios/casper-marketplace --skill youtube-tools
Agent 安装分布
Skill 文档
YouTube Tools (yt-dlp)
Overview
Free, local YouTube operations using yt-dlp. No API keys required, no per-video costs. Works offline after installation.
When to Use This vs Apify
âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
â DECISION: YouTube Tools (yt-dlp) vs Apify â
âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¤
â â
â Use youtube-tools (FREE) when: â
â âââ Downloading videos to local storage â
â âââ Extracting transcripts/subtitles â
â âââ Getting video metadata (title, duration, views, etc.) â
â âââ Bulk downloading playlists or channels â
â âââ Converting to audio-only (MP3) â
â âââ You want zero API costs â
â â
â Use apify-scrapers when: â
â âââ Scraping YouTube SEARCH results â
â âââ Getting comments at scale â
â âââ Channel analytics and statistics â
â âââ Trending video discovery â
â âââ You need cloud-based processing â
â â
âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
Quick Decision Tree
What do you need?
â
âââ Download video(s)
â âââ Single video â scripts/download_video.py URL
â âââ Multiple videos â scripts/download_video.py --urls-file list.txt
â âââ Playlist â scripts/download_video.py "playlist_url"
â âââ Audio only â scripts/download_video.py URL --audio-only
â âââ Specific quality â scripts/download_video.py URL --quality 720p
â
âââ Get transcript/subtitles
â âââ Auto-generated captions â scripts/get_transcript.py URL
â âââ Manual subtitles â scripts/get_transcript.py URL --manual-only
â âââ Specific language â scripts/get_transcript.py URL --lang es
â âââ All available â scripts/get_transcript.py URL --all-langs
â
âââ Get video metadata
â âââ Single video â scripts/get_video_info.py URL
â âââ Multiple videos â scripts/get_video_info.py --urls-file list.txt
â âââ Playlist info â scripts/get_video_info.py "playlist_url"
â
âââ Advanced
âââ Age-restricted â scripts/download_video.py URL --cookies-from-browser chrome
âââ Private videos â Requires authentication (see references/yt-dlp-guide.md)
âââ Live streams â scripts/download_video.py URL --live-from-start
Environment Setup
# Install yt-dlp (required)
pip install yt-dlp
# Optional: Install ffmpeg for format conversion
# macOS
brew install ffmpeg
# Ubuntu/Debian
sudo apt install ffmpeg
# Windows
winget install ffmpeg
No API keys required! This is completely free.
Common Usage
Download Single Video
python scripts/download_video.py "https://www.youtube.com/watch?v=VIDEO_ID"
Download with Specific Quality
python scripts/download_video.py "https://youtu.be/VIDEO_ID" --quality 1080p
Download Audio Only (MP3)
python scripts/download_video.py "https://youtube.com/watch?v=VIDEO_ID" --audio-only
Download Entire Playlist
python scripts/download_video.py "https://youtube.com/playlist?list=PLAYLIST_ID" --output-dir ./videos
Bulk Download from File
# Create urls.txt with one URL per line
python scripts/download_video.py --urls-file urls.txt --output-dir ./downloads
Get Transcript
python scripts/get_transcript.py "https://youtube.com/watch?v=VIDEO_ID"
Get Transcript in Specific Language
python scripts/get_transcript.py "https://youtu.be/VIDEO_ID" --lang es
Get Video Metadata
python scripts/get_video_info.py "https://youtube.com/watch?v=VIDEO_ID"
Get Metadata for Multiple Videos
python scripts/get_video_info.py --urls-file videos.txt --output metadata.json
Output Location
All outputs save to .tmp/youtube/ by default:
- Videos:
.tmp/youtube/videos/ - Audio:
.tmp/youtube/audio/ - Transcripts:
.tmp/youtube/transcripts/ - Metadata:
.tmp/youtube/metadata/
Cost
FREE – No API keys, no per-video costs, no subscriptions.
Security Notes
Safe by Design
- URL validation: Only accepts YouTube URLs (youtube.com, youtu.be)
- Filename sanitization: Removes dangerous characters
- Output restriction: Only writes to
.tmp/directory - No shell injection: Uses subprocess with argument lists, not string concatenation
- No stored credentials: Cookies only used when explicitly requested
Copyright Warning
- Only download content you have rights to access
- Respect YouTube’s Terms of Service
- Do not redistribute copyrighted content
- Use for personal/educational purposes
Rate Limiting
- yt-dlp has built-in rate limiting
- For bulk downloads, use
--sleep-interval 5to avoid throttling - YouTube may temporarily block IPs with excessive requests
Troubleshooting
Issue: “Video unavailable”
Cause: Video is private, age-restricted, or region-locked
Solution: Use --cookies-from-browser chrome for age-restricted content
Issue: “Unable to extract video data”
Cause: YouTube changed their page structure
Solution: Update yt-dlp: pip install -U yt-dlp
Issue: No subtitles found
Cause: Video has no captions (auto or manual)
Solution: Use --list-subs to see available subtitles first
Issue: Slow downloads
Cause: YouTube throttling or network issues
Solution: Try --concurrent-fragments 4 for faster downloads
Issue: Format conversion failed
Cause: ffmpeg not installed Solution: Install ffmpeg (see Environment Setup)
Integration Patterns
Download + Transcribe + Summarize
# 1. Download video
python scripts/download_video.py "URL" --output-dir .tmp/video
# 2. Get transcript
python scripts/get_transcript.py "URL" --output .tmp/transcript.txt
# 3. Use content-generation to summarize
# (transcript file is now ready for summarization)
Bulk Research Workflow
# 1. Get metadata for research videos
python scripts/get_video_info.py --urls-file research_videos.txt --output .tmp/metadata.json
# 2. Download transcripts for text analysis
python scripts/get_transcript.py --urls-file research_videos.txt --output-dir .tmp/transcripts
# 3. Use parallel-research to analyze content
Course Content Download
# Download entire playlist as course modules
python scripts/download_video.py "PLAYLIST_URL" --output-dir .tmp/course --quality 720p
# Get all transcripts for notes
python scripts/get_transcript.py "PLAYLIST_URL" --output-dir .tmp/course/transcripts
Resources
- references/yt-dlp-guide.md – Complete yt-dlp reference with all options
- yt-dlp documentation: https://github.com/yt-dlp/yt-dlp#readme