目录

  • 前言
  • 0.科学上网
  • 1.安装yt-dlp
  • 2.安装FFmpeg
    • 2.1 官网下载
    • 2.2 环境变量配置
    • 2.3 安装成果检查
  • 3. 上手下载
    • 3.1 基础格式
    • 3.2 脚本地址查询
    • 3.3 常用参数和用例展示
      • 3.3.1 陈列资源 -F, --list-formats
      • 3.3.2 格式选择 -f , --format
      • 3.3.3 字幕下载 --write-subs,--write-auto-subs
      • 3.3.4 批量下载 -a FILE
      • 3.3.5 片段提取 --download-sections
      • 3.3.6 格式化命名和存储 -o TEMPLATE
      • 3.3.7 更多
    • 3.4 其他平台使用
      • 3.4.1 b站
  • 4. 进阶技巧
    • 4.1 Aria2下载加速
      • 4.1.1 官网下载
      • 4.1.2 环境变量配置
      • 4.1.3 命令行调用格式
      • 4.1.4 在yt-dlp中调用Aria2
    • 4.2 Python程序调用
  • 5.报错解决
    • 5.1 无法连接
  • 6. 拓展阅读

前言

yt-dlp是一个命令行程序,可在youtube、twitch、bilbili、西瓜视频等一千多个网站下载视频资源1。国内平台的解析工具已经存在很多,像you-get之类,我们主要用它来下载海外视频。
作为youtube-dl的增补版,yt-dlp有着比起前辈更快的速度,以及众多新特性。本文仅记录win10系统python环境下的跑通方法。在尝试前,先确保本地存在3.7+的python版本,推荐安装ffmpeg、ffprobe等依赖,以方便视频合并、转码等后续处理。
官方项目地址:https://github.com/yt-dlp/yt-dlp

本文仅作学习记录,如有错误欢迎提出,持续更新。


0.科学上网

下载youtube视频的前提是自由访问,默认读到本文的应该都已实现科学访问了~
没有的同学请先行寻找合适的加速器

1.安装yt-dlp

打开命令行输入:

pip install yt-dlp

速度慢可以更换pip镜像源,或在pypi下载离线安装

2.安装FFmpeg

这里的FFmpeg指二进制文件,而非同名的python包,其中包含了ffmpeg、ffprobe、ffplay三大工具。

2.1 官网下载

访问网址:https://www.gyan.dev/ffmpeg/builds
全文搜索CTRL+F找到ffmpeg-release-full.7z这个安装包,点击下载
解压到本地目录中,打开bin文件夹,地址栏复制本地路径

2.2 环境变量配置

计算机右键【属性】-> 【高级系统设置】->【高级】-> 【环境变量】-> 【用户变量】
双击Path,新建一条,在变量值里粘贴复制的路径

2.3 安装成果检查

WIN+R 输入cmd,命令行中测试一下,输入ffmpeg回车,出现下图类似结果安装成功

3. 上手下载

3.1 基础格式

在想要保存的目录下打开命令行(地址栏输入cmd回车),按照如下格式书写命令:

yt-dlp [OPTIONS] [--] URL [URL...]

yt-dlp必须在前,OPTIONS和URL填写不分先后

基础用法示例:

# --proxy 使用指定的HTTP/HTTPS/SOCKS代理。 e.g. socks5://user:pass@127.0.0.1:1080/
# 127.0.0.1表示本机ip,1080表示当前使用的端口,请根据本机情况查询并更改,见3.2
# URL填写想下载的视频地址# 下载单个视频
yt-dlp --proxy socks5://127.0.0.1:1080 https://www.youtube.com/watch?v=NtKJSHW68p4# 下载播放列表的所有视频
yt-dlp --proxy socks5://127.0.0.1:1080 https://www.youtube.com/playlist?list=PLqWr7dyJNgLJ79otw7N9CXQ_AU0Fm04aq

3.2 脚本地址查询

点右下角网络图标进入【网络和Internet设置】,选择【代理】
找到【使用设置脚本】,开启
检查命令中的ip和端口和【脚本地址】是否一致

3.3 常用参数和用例展示

根据使用需求,追加命令参数,体验yt-dlp的丰富玩法,具体见项目自述,也可在命令行输入yt-dlp --help查看说明

3.3.1 陈列资源 -F, --list-formats

  • 含义:列出所有文件的格式信息
  • 用法:
yt-dlp [--proxy ...] URL -F
yt-dlp [--proxy ...] URL --list-formats


对图中的标题做一下阅读理解:

ID EXT RESOLUTION FPS CH FILESIZE TBR PROTO
编码 扩展名 分辨率(宽x高) 每秒画面帧数 音频通道数 文件字节数 音频和视频的平均比特率(KBit) 下载协议 (http, https, rtsp, rtmp, rtmpe, mms, f4m, ism, http_dash_segments, m3u8, or m3u8_native)
VCODEC VBR ACODEC ABR ASR MORE INFO
视频编码方案 平均视频码率(KBit) 音频编码方案 平均音频码率(KBit) 音频采样率(hz) 补充说明

3.3.2 格式选择 -f , --format

  • 含义:格式选择器,根据要求下载指定格式的音视频资源

  • 说明:未传参时,默认下载最佳质量的格式。按特定要求下载时,写明视频和音频的格式要求。支持单独下载纯视频/音频,合并下载用"+“连接,各自分开下载用”,“,从左到右选择第一个可用资源下载用”/"

  • 示例:

# 根据id,下载编号597的资源作为视频画面,599作为视频声音,把图像和音轨合并为MP4格式导出
yt-dlp -f 597+599 [--proxy ...] URL --merge-output-format mp4# 下载编码为22的文件
yt-dlp -f webm [--proxy ...] URL# 下载最佳质量的单个webm文件(目前支持3gp, aac, flv, m4a, mp3, mp4, ogg, wav, webm格式)
yt-dlp -f webm [--proxy ...] URL# 分开下载视频和音频,格式化命名,按title.ID.EXT模板输出
yt-dlp -f "bv,ba/b" -o "%(title)s.f%(format_id)s.%(ext)s" [--proxy ...] URL# 条件过滤,通过表格中的各项条件筛选目标规格的资源
-f w    # 下载质量最差的资源文件(同时包含音视频),wv纯视频,wa纯音频,适合测试命令时使用
-f "best[height=720]"     # 筛选最佳质量的720p视频
-f "[filesize>10M]"    # 筛选>10M的文件
-f "all[vcodec=none]"     # 筛选所有纯音频
-f "(mp4,webm)[height<480]"        # 筛选低于480p的最佳mp4视频和webm音轨,合并
-f 'bv[height=1080][ext=mp4]+ba[ext=m4a]' --merge-output-format mp4  # 筛选1080p的mp4视频,与最佳的m4a音频下载合并

3.3.3 字幕下载 --write-subs,–write-auto-subs

  • 含义:下载字幕(投稿外挂的或自动翻译生成的)
  • 用例:
yt-dlp [--proxy ...] URL --list-subs # 列出所有支持的字幕信息(语言标识名、语言名、文件格式)

下图列出的字幕使用--write-subs下载

下图的字幕使用--write-auto-subs下载

# 下载视频时一同下载srt格式的中文字幕,--sub-lang后的值从图中的Langeuage列取得
yt-dlp --write-auto-subs --sub-format srt --sub-lang zh-Hans [--proxy ...] URL# 单独下载最佳格式的英文字幕
yt-dlp --write-auto-subs --sub-format best --sub-lang en --skip-download [--proxy ...] URL# 在视频中嵌入自动生成的阿拉伯语字幕,字幕嵌入操作仅适用于mp4,Webm和MKV视频
yt-dlp --write-auto-subs --sub-lang ar --embed-subs --merge-output-format mp4 [--proxy ...] URL

3.3.4 批量下载 -a FILE

下载文本中所有视频

yt-dlp -a urls.txt [--proxy ...] URL

3.3.5 片段提取 --download-sections

下载时间戳范围的片段

yt-dlp --download-sections "*1:30-inf" [--proxy ...] URL      # 前缀*,范围边界0:00 - inf

下载指定章节的片段

yt-dlp --download-sections "intro" [--proxy ...] URL

下载所有章节切片并按id.title.ext命名,同时下载一份完整的视频。
输出模板参数有section_number,section_title,section_start和section_end

yt-dlp --split-chapters -o "chapter:%(section_number)03d. %(section_title)s.%(ext)s" [--proxy ...] URL

3.3.6 格式化命名和存储 -o TEMPLATE

格式化命名文件并指定路径保存

-o "~/YouTube/%(title)s.%(ext)s"
-o "%(uploader)s/%(upload_date)s - %(title)s (%(id)s).%(ext)s"
-o "%(duration>%H-%M-%S)s" # 视频时长

输出模板的语法见output-template

3.3.7 更多

  • –merge-output-format FORMAT:视频合并操作
  • -j, --dump-json:打印JSON信息
  • –embed-thumbnail:将视频缩略图嵌入视频封面,需要合并操作
    yt-dlp --embed-thumbnail --merge-output-format mp4 [--proxy ...] URL
    
  • –embed-metadata:嵌入元数据,如视频简介描述,需要合并操作
  • –audio-format FORMAT:纯音频下载,支持格式转换
    yt-dlp -x --audio-format mp3 [--proxy ...] URL -o '%(title)s_%(id)s.mp3'
    
  • –skip-download:跳过视频下载,仅下载相关文件
  • –cookies-from-browser BROWSER:对于要求登录或会员才可下载的网址,调取浏览器cookies
    目前支持的浏览器有brave, chrome, chromium, edge, firefox, opera, safari, vivaldi

3.4 其他平台使用

3.4.1 b站

下载高清视频需要调取浏览器cookie登录

# 下载单P视频
yt-dlp https://www.bilibili.com/video/BV1dM411t7Ls --cookies-from-browser chrome
# 分P视频仅下载P1
yt-dlp https://www.bilibili.com/video/BV1vs4y1b7rU?p=1 --cookies-from-browser chrome

4. 进阶技巧

4.1 Aria2下载加速

作为外部下载器加速下载,多线程并发,提升带宽利用率。 详情见Aria2 Manual
下面仅介绍arias作为命令行工具的下载配置以及基础用法

4.1.1 官网下载

访问官网releases页面,根据选择的版本和本机环境在Assets下找到安装包,点击下载
我这里选择windows x64的安装包

下载成功后解压,为了方便我直接放D盘并改名aria2

4.1.2 环境变量配置

打开文件夹,复制aria2c.exe的路径(我这里是D:\aria2),在环境变量path中配置(方法同2.2)

快捷操作:
win+R调出【运行】对话框 -> 输入sysdm.cpl,回车打开【系统属性】 -> 【高级】-> 【环境变量】 -> 【用户变量】
双击path新建,粘贴路径

4.1.3 命令行调用格式

aria2c [OPTIONS] [URI | MAGNET | TORRENT_FILE | METALINK_FILE]...

命令行输入aria2c -h查看具体参数说明
最简单的用法是aria2c URL,例如:

aria2c https://www.bilibili.com/

4.1.4 在yt-dlp中调用Aria2

# --downloader:指定下载器,aria2c以外还支持avconv,axel,curl,ffmpeg,httpie,wget
# --downloader-args:下载参数 -c:断点续传;-j:并发数;-x:线程数(最多16);-k:分段(每段1M)yt-dlp --downloader aria2c --downloader-args aria2c:"-c -j 3 -x 8 -k 1M" [--proxy ...] URL

4.2 Python程序调用

基础用例:

from yt_dlp import YoutubeDLURLS = ['https://www.youtube.com/watch?v=BaW_jenozKc']
with YoutubeDL() as ydl:ydl.download(URLS)

更多用例参考见embedding-examples
了解可用参数和公共函数列表,见yt_dlp.YoutubeDL.py

5.报错解决

5.1 无法连接

WARNING: [youtube] Unable to download webpage: <urlopen error [WinError 10061] 由于目标计算机积极拒绝,无法连接。>

解决:

  1. 检查vpn或代理是否正常连接
  2. 检查命令的地址和脚本地址是否一致

6. 拓展阅读

ArchWiki:https://wiki.archlinux.org/title/Yt-dlp


  1. 支持的视频列表见supportedsites ↩︎

Win10 Python yt-dlp下载youtube视频 | 安装使用详细教程相关推荐

  1. win10安装Tomcat10详细教程

    win10安装Tomcat10详细教程 提示:安装Tomcat前需要本机有java环境,如未有java环境的,可以先参考此篇博文: win10安装JDK1.8详细教程. 文章目录 win10安装Tom ...

  2. python2020安装教程_PyCharm 2020.2.2 x64 下载并安装的详细教程

    1.在浏览器上搜索PyCharm https://www.jetbrains.com/pycharm/download/#section=windows 2.点击Download(根据需要选择版本) ...

  3. mysql 8.0.22_最新版MySQL 8.0.22下载安装超详细教程(Windows 64位)

    前言 前几天下载安装了最新版的MySQL 8.0.22,遇到了不少问题,参考了一些方法,最终得以解决.今天将自己的安装过程记录下来,希望对各位有所帮助. 一.MySQL 8.0.22官网下载 点击进入 ...

  4. python中pytest教程_Pytest安装新手详细教程

    相信软件测试的从业者对Pytest都不会感到陌生,它是一个功能丰富的Python测试框架,因其简单灵活,支持复杂的功能测试和丰富的第三方插件而备受大家喜爱.下面我将手把手教大家如何安装Pytest,一 ...

  5. MySQL命令行下载安装配置——详细教程

    安装一定要装在C盘,下载别的盘可能不好使 文章目录 免安装版的MySQL MySQL命令行下载 1.打开官网下载 2.点击 MySQL Community Server 3.选择适合的版本 MySQL ...

  6. 如何下载并安装pycharm(详细教程)

    如何下载并安装pycharm(详细教程) - 第一步:下载安装包 搜索引擎:"pycharm官网"进入pycharm官网页面 点击download 选择:community社区版本 ...

  7. Windows安装You-get详细教程和问题解决分享

    写这篇文章是因为,当我按照网上的方法安装和下载you-get时,命令行提示you-get不是可使用的命令.在找解决方法时,一直无法成功使用.遇到的问题有: SSL验证问题 you-get不是内部命令. ...

  8. 大数据平台Ambari2.7.4+HDP3.1.4安装(超详细教程)

    大数据平台Ambari2.7.4+HDP3.1.4安装(超详细教程) Ambari2.7.4+HDP3.1.4是最后一个免费版本,新版本需要授权. 因工作需要,安装大数据集群,了解到Ambari属于A ...

  9. .net4.5对应的安装mysql dll文件的版本_cmd下使用mysql插入中文出现无法退出语句的情况!终极解决办法! 安装mysql详细教程。...

    当你插入中文时遇到这种情况,始终无法退出. 当前数据库:网上下载的奇奇怪怪版本5.5 当前系统win10 当前CMD输入编码utf8 数据库编码utf8 表编码utf8 mysql> inser ...

最新文章

  1. Android从放弃到精通 第二天 我还好
  2. Java面对面向程序设计_语言与文化网课章节测试答案
  3. php屏幕共享功能,利用无线投屏技术同屏直播,精彩随时共享
  4. Java中如何获得集合变量的集合中的类型参数
  5. 在 JavaFX 中,如何计算文本所占像素的宽度
  6. C# WPF MVVM开发框架Caliburn.Micro自定义引导程序④
  7. webpack基础使用Loader(三)
  8. EMR Spark Runtime Filter性能优化
  9. 支付巨头Visa宣布计划在巴西将加密货币服务引入传统银行
  10. 多领域合作 浪潮与美亚柏科赋能信息安全
  11. text 热敏打印机_ESC/POS热敏打印机示例
  12. Oracle与SQL Server的语法区别——Oracle数据库学习
  13. 书单|VR开发内功修炼书单
  14. 详细解说“黑客”们热衷的热门抓鸡技术
  15. TCP/UDP测试工具大全
  16. 计算机伦理学理论分析三大思想,人工道德能动性的三种反驳进路及其价值
  17. Winform2、(C#) 设置编译后.exe执行文件的图标
  18. opencart seo优化_opencart seo 优化技巧有哪一些
  19. 海湾gst5000主机消防广播_海湾消防主机JB-QG_T-GST5000_JB-QB-GST500控制器说明书.doc
  20. 追加贷显示服务器出错,小蜜蜂财务软件常见问题汇总

热门文章

  1. 三角函数的局限和改进思路
  2. springboot——关于template might not exist or might not be accessible的问题
  3. 重磅!复宏汉霖首款产品汉利康®获批,成中国生物类似药里程碑
  4. 论文阅读: 图像分类中的注意力机制(attention)
  5. 安霸(ambarella) s2l视频处理流程
  6. tornado中数据库ORM操作(二):通过peewee-async集成到tornado中
  7. 男子与女友争吵后将10公斤重电脑椅从15楼扔下 获刑6个月
  8. C 关于中文汉字字符串
  9. 基于顺序存储结构的图书信息表
  10. Google支付 常见错误