universal-media-downloader

$npx mdskill add cat-xierluo/legal-skills/universal-media-downloader

Download media from major video and podcast sites using yt-dlp, handling logins and restrictions.

  • Retrieves video or audio content from various online platforms via a single link.
  • Integrates with yt-dlp to support sites like YouTube, Bilibili, and podcast feeds.
  • Uses provided cookies or proxy settings to bypass access restrictions like 403 errors.
  • Delivers the downloaded file directly to the user or specified local directory.
SKILL.md
.github/skills/universal-media-downloaderView on GitHub ↗
---
name: universal-media-downloader
homepage: https://github.com/cat-xierluo/legal-skills
author: 杨卫薪律师(微信ywxlaw)
version: "0.2.0"
description: 输入各类视频网站/播客平台链接后,自动下载对应媒体文件并交付给用户。优先使用 yt-dlp 覆盖抖音(Douyin)、B站(Bilibili)、YouTube 等常见视频网站,也可用于可直接暴露音频地址的播客平台(如小宇宙单集链接)。当遇到 403/登录/年龄或地区限制时,支持使用 cookies.txt 重试;对于可能存在 DRM/加密或条款限制的平台(例如部分 Spotify 内容),应提示用户仅下载其有权保存的内容,并在不可下载时建议改用官方离线/导出渠道或提供原始 RSS/直链。注意:抖音图文笔记暂不支持自动下载,需手动处理。
license: MIT
---

# Universal Media Downloader(通用视频/播客下载)

## 适用范围

**优先覆盖(通常可直接用)**
- **抖音视频**:`douyin.com`、`v.douyin.com` 等视频链接
- **抖音图文笔记**:暂不支持自动下载(反爬限制),需手动截图
- **B站**:`bilibili.com`、`b23.tv` 等
- **YouTube**:`youtube.com`、`youtu.be`
- 以及其它 **yt-dlp 支持的网站**(数量很多)

**播客平台**
- **小宇宙(单集/节目页)**:多数情况下可直接下载音频(yt-dlp 通常能用)
- 其它播客平台:如果页面可解析出音频直链,通常也能下载

> 合规提示:仅用于下载你**有权保存**的内容(例如你自己上传/拥有版权/获得授权/平台允许离线的内容)。遇到 DRM/加密或平台限制时,不要尝试绕过。

## 快速开始

### 1)下载视频(默认)

- 命令:
  - `python scripts/download_media.py "<URL>"`

- 默认保存目录:
  - 技能目录下的 `downloads/` 文件夹(自包含)
  - 可通过 `--out-dir` 参数自定义输出路径

### 2)只下载音频(适合播客 / 只想要 MP3)

- 命令:
  - `python scripts/download_media.py --audio-only --audio-format mp3 "<URL>"`

### 3)遇到 403 / 需要登录 / 风控拦截:用 cookies 重试

- 让用户提供浏览器导出的 **Netscape 格式** `cookies.txt`

- 然后重试:
  - `python scripts/download_media.py --cookies "/path/to/cookies.txt" "<URL>"`

### 4)需要代理(可选)

- 例如:
  - `--proxy "socks5://127.0.0.1:7890"`

### 5)指定下载路径

- 用户可通过自然语言指定保存位置,AI 应自动转换为 `--out-dir` 参数
- 示例:
  - 用户说"下载到桌面" → `--out-dir ~/Desktop`
  - 用户说"保存到 Videos/bilibili" → `--out-dir "~/Videos/bilibili"`
  - 用户说"下载到这个文件夹"(指定某路径)→ 使用用户指定的绝对路径
- **注意**:确保目标目录存在,如不存在可自动创建

## 平台差异与限制(重要)

- **YouTube/B站/抖音**:
  - 常见失败原因:年龄限制、地区限制、频繁请求触发风控、需要登录
  - 处理方式:cookies、代理、或降低并发/等待后重试
  - YouTube 额外提示:若出现 *Signature solving failed / JS challenge* 警告,可按 yt-dlp 的 EJS 指引启用挑战求解组件(例如加 `--remote-components ejs:github`),或让用户提供 cookies

- **Spotify**:
  - Spotify 上的内容可能存在 DRM、账号权限/订阅限制,且“下载”可能违反平台条款。
  - 本 skill **不保证** Spotify 链接一定可下载。
  - 可行替代:
    - 使用官方离线功能(若平台提供)
    - 提供该播客的 **RSS/音频直链**(如果你拥有/可获得),再用本脚本下载

## Bundled scripts

- `scripts/download_media.py`
  - 基于 `yt-dlp` 的通用下载器
  - 输出:成功时最后一行 `SAVED_FILEPATH=...`
  - **AI 使用指引**:当用户指定保存路径时,自动使用 `--out-dir` 参数
  - 参数:
    - `url`(必填)
    - `--audio-only` / `--audio-format`
    - `--subtitles`(可选,自动下载字幕)
    - `--sub-lang`(可选,字幕语言,默认 all)
    - `--cookies`(可选)
    - `--proxy`(可选)
    - `--out-dir`(可选,自定义输出目录)

## 依赖

### 系统依赖

| 依赖 | 安装方式 |
|------|----------|
| `yt-dlp` | `pip install yt-dlp` |
| `ffmpeg`(可选,用于字幕提取和音频转换) | macOS: `brew install ffmpeg`<br>Linux: `sudo apt-get install ffmpeg` |

### Python 包

无需额外 Python 依赖,`yt-dlp` 已包含所需库。
More from cat-xierluo/legal-skills