Skip to main content

A yt-dlp plugin package (ce).

Project description

项目简介

ce-yt-dlp 全称 Custom Extension yt-dlp, 是对 yt-dlp 的外部插件集合,提供可按需开启的定制能力,在不改动核心库的前提下切换到增强版 YoutubeDL 及自定义 YouTube 提取器。

目录

部署流程

项目依赖 reqeusts 第三方请求库及可运行的yt-dlp环境, 在安装yt-dlp 环境时, 可通过:pip install -e '.[default]' or pip install '.[default]' 进行依赖安装。

  1. yt-dlp 项目根目录下放置 yt_dlp_plugins项目。
  2. 编写下载脚本时把原生的YoutubeDL 替换成插件中的 CustomYoutubeDL, yt-dlp 的使用方式不变。
  3. 使用示例程序 main.py(见下方示例配置),即可触发插件逻辑:
from yt_dlp_plugins.custom_youtube_dl import CustomYoutubeDL


ydl_opts = {
    "outtmpl": "downloads/%(id)s.%(format_id)s.%(ext)s",
    "format": "bestvideo*+bestaudio/best",
    "subtitleslangs": ["en", "en-orig", "zh-Hans", "zh-Hant"],
    "writeautomaticsub": True,
    "subtitlesformat": "json3",
}
VIDEO_URL = "https://www.youtube.com/watch?v=wSSmNUl9Snw"
with CustomYoutubeDL(ydl_opts) as ydl:
    info = ydl.extract_info(VIDEO_URL, download=True)

使用选项

自定义功能选项

使用自定义功能必须先开启 use_custom_youtube_dl 总开关

use_custom_youtube_dl                 自定义功能总开关, 默认关闭状态(False)使用原生 YoutubeDL功能,设置为True 开启自定义功能。
use_custom_writeautomaticsub          多字幕下载时写入字幕失败仅告警并继续下一条,默认关闭状态(False), 设置为True 开启。

自定义提取器选项

使用自定义提取器选项必须先开启 use_custom_youtube_dl 总开关

use_custom_plugins                    自定义插件总开关, 默认关闭状态(False)使用原生 YoutubeIE功能,设置为True 开启自定义功能。
use_custom_player_client              自定义播放器客户端列表,例如:["tv", "web_safari", "android_sdkless"], 注意此功能优先级高于原生       extractor_args的设置
use_custom_download_webpage_handle    自定义web页面下载程序开关,在原生下载器出问题时可进行切换。默认关闭状态(False), 设置为True 开启。
use_custom_sabr                       指定使用 player 生成 potoken的客户端,例如:["web_safari"],多个客户端使用逗号(,)分割

自定义功能简介

位于yt_dlp_plugins/custom_youtube_dl.py 中,为自定义功能实现,通过对 YoutubeDL 方法或属性的覆盖或重写,达到自定义的业务目标

使用示例

from yt_dlp_plugins.custom_youtube_dl import CustomYoutubeDL


ydl_opts = {
    "outtmpl": "downloads/%(id)s.%(format_id)s.%(ext)s",
    "format": "bestvideo*+bestaudio/best",
    "subtitleslangs": ["en", "en-orig", "zh-Hans", "zh-Hant"],
    "writeautomaticsub": True,
    "subtitlesformat": "json3",

    # 开启开启自定义功能,并使用多字幕下载功能
    "use_custom_youtube_dl": True,
    "use_custom_writeautomaticsub": True
}
VIDEO_URL = "https://www.youtube.com/watch?v=wSSmNUl9Snw"
with CustomYoutubeDL(ydl_opts) as ydl:
    info = ydl.extract_info(VIDEO_URL, download=True)

底层覆写方法一览与设计目的

方法名 返回类型 说明
_write_subtitles list 字幕写入更鲁棒。默认会因单条字幕失败而抛异常中断;覆写后改为 warn 并继续其它语言,避免整次下载被字幕拖垮。
report_error 向上抛出异常 自定义错误码处理
dl 下载器 下载器 hook 点,可自定义下载器或覆写原生下载器逻辑

自定义提取器

位于 yt_dlp_plugins/extractor/custom_youtube.py 中,为自定义提取器插件,通过对 YoutubeIE 方法或属性的覆盖或重写,达到自定义的业务目标

使用示例

from yt_dlp_plugins.custom_youtube_dl import CustomYoutubeDL


ydl_opts = {
    "outtmpl": "downloads/%(id)s.%(format_id)s.%(ext)s",
    "format": "bestvideo*+bestaudio/best",
    "subtitleslangs": ["en", "en-orig", "zh-Hans", "zh-Hant"],
    "writeautomaticsub": True,
    "subtitlesformat": "json3",

    # 开启自定义插件功能, 并使用指定客户端功能
    "use_custom_plugins": True,
    "use_custom_player_client": [
        "tv",
        "web_safari",
        "android_sdkless",
    ]
}
VIDEO_URL = "https://www.youtube.com/watch?v=wSSmNUl9Snw"
with CustomYoutubeDL(ydl_opts) as ydl:
    info = ydl.extract_info(VIDEO_URL, download=True)

底层覆写方法一览与设计目的

方法名 返回类型 说明
_get_requested_clients list 下载客户端列表
_search_regex str 正则匹配,从 HTML 或 API 返回的 response 中提取数据
_download_webpage_handle Tuple 配置信息下载器
_request_webpage response urllib 请求发送器,粒度更细,可在提交请求时更改请求信息,如 m3u8 清单下载

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

ce_yt_dlp-0.0.4.tar.gz (10.9 kB view details)

Uploaded Source

Built Distribution

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

ce_yt_dlp-0.0.4-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

Details for the file ce_yt_dlp-0.0.4.tar.gz.

File metadata

  • Download URL: ce_yt_dlp-0.0.4.tar.gz
  • Upload date:
  • Size: 10.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.0

File hashes

Hashes for ce_yt_dlp-0.0.4.tar.gz
Algorithm Hash digest
SHA256 1a9c17c24ffb2f571a360481102375af1b16ef73225e7468d2c6187ded0592a0
MD5 b9f8fcb32a469f04c9767f66446c5f25
BLAKE2b-256 946e6abb0c0c205899b9ce24832d68deecc6e1e7ae0cf38f0e6745069f27f3d5

See more details on using hashes here.

File details

Details for the file ce_yt_dlp-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: ce_yt_dlp-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 13.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.0

File hashes

Hashes for ce_yt_dlp-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 aec2de0f109631466715b58be669fc3e1b22e8dff332683f9f4a5d93c5b4eaa0
MD5 e53d1775fd6660945d7eb9ac13bcc4d4
BLAKE2b-256 c9f0e0d0382b497b3d79356a5d456060eea10447ffa83ddb63a5365cbe655c7a

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