python实现音视频下载器

一、环境准备

确保当前系统已安装了wxPython 、 yt-dlp 和FFmpeg。当前主要支持下载youtube音视频

1、安装wxPython

pip install wxPython

2、安装yt-dp

pip install wxPython yt-dlp

3、安装FFmpeg

在Windows 10上通过命令行安装FFmpeg,最简便的方式是使用包管理器,比如Scoop或Chocolatey。以下是使用这两种工具的步骤:

① 使用Scoop安装FFmpeg

如果还没有安装Scoop,首先需要按照Scoop官网上的说明进行安装。打开PowerShell并运行以下命令来安装Scoop(如果尚未安装):

Set-ExecutionPolicy RemoteSigned -scope CurrentUser
irm get.scoop.sh | iex

安装完Scoop后,你可以通过以下命令安装FFmpeg:

scoop install ffmpeg

② 使用Chocolatey安装FFmpeg

如果更倾向于使用Chocolatey,首先确保已经安装了Chocolatey。可以通过Chocolatey官网获取安装指南。
在这里插入图片描述

通常,可以在管理员模式下的PowerShell中运行以下命令来安装Chocolatey:

Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1'))

在这里插入图片描述

安装完Chocolatey后,可以通过以下命令安装FFmpeg:

choco install ffmpeg

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
无论你选择哪种方式安装FFmpeg,完成后都可以通过命令行输入以下命令来验证是否安装成功:

ffmpeg -version

在这里插入图片描述

如果你看到FFmpeg的版本信息以及其他相关细节,那么说明FFmpeg已经正确安装,并且可以通过命令行使用了。

请注意,为了使这些命令在任何目录下都能生效,可能需要重启计算机或者重新打开一个新的命令提示符窗口。此外,确保你的环境变量Path包含了FFmpeg的安装路径,这样系统才能识别ffmpeg命令。通过上述方法安装时,通常会自动处理好这个问题。

二、代码编写

编写名字为downloader.py的python代码文件

import wx
import yt_dlp
import threadingclass DownloaderFrame(wx.Frame):def __init__(self):super().__init__(None, title="Downloader", size=(400, 350))self.panel = wx.Panel(self)self.source_label = wx.StaticText(self.panel, label="Audio or video URL:")self.source_text = wx.TextCtrl(self.panel)self.source_label.SetBackgroundColour(wx.Colour(173, 216, 230))  # 设置背景为浅蓝色self.source_label.SetForegroundColour(wx.Colour(0, 0, 128))  # 设置文本颜色为黑色,确保对比度良好self.folder_label = wx.StaticText(self.panel, label="Save Folder:")self.folder_text = wx.TextCtrl(self.panel)self.folder_label.SetBackgroundColour(wx.Colour(173, 216, 230))  # 设置背景为浅蓝色self.folder_label.SetForegroundColour(wx.Colour(0, 0, 128))  # 设置文本颜色为黑色,确保对比度良好self.folder_button = wx.Button(self.panel, label="Browse...")self.folder_button.Bind(wx.EVT_BUTTON, self.browse_folder)self.quality_label = wx.StaticText(self.panel, label="Quality:")self.quality_choice = wx.ComboBox(self.panel, choices=[], style=wx.CB_READONLY)self.quality_label.SetBackgroundColour(wx.Colour(173, 216, 230))  # 设置背景为浅蓝色self.quality_label.SetForegroundColour(wx.Colour(0, 0, 128))  # 设置文本颜色为黑色,确保对比度良好self.start_button = wx.Button(self.panel, label="Start Download")self.start_button.Bind(wx.EVT_BUTTON, self.start)self.process_label = wx.StaticText(self.panel, label="Percentage:")self.process_bar = wx.Gauge(self.panel, range=100)self.process_label.SetBackgroundColour(wx.Colour(173, 216, 230))  # 设置背景为浅蓝色self.process_label.SetForegroundColour(wx.Colour(0, 0, 128))  # 设置文本颜色为黑色,确保对比度良好self.sizer = wx.BoxSizer(wx.VERTICAL)self.sizer.Add(self.source_label, 0, wx.ALL, 5)self.sizer.Add(self.source_text, 0, wx.EXPAND | wx.ALL, 5)self.sizer.Add(self.folder_label, 0, wx.ALL, 5)self.sizer.Add(self.folder_text, 0, wx.EXPAND | wx.ALL, 5)self.sizer.Add(self.folder_button, 0, wx.ALL, 5)self.sizer.Add(self.quality_label, 0, wx.ALL, 5)self.sizer.Add(self.quality_choice, 0, wx.EXPAND | wx.ALL, 5)self.sizer.Add(self.start_button, 0, wx.ALL, 5)self.sizer.Add(self.process_label, 0, wx.ALL, 5)self.sizer.Add(self.process_bar, 0, wx.EXPAND | wx.ALL, 5)self.panel.SetSizer(self.sizer)self.Show()def browse_folder(self, event):dlg = wx.DirDialog(self, "Choose a directory", style=wx.DD_DEFAULT_STYLE)if dlg.ShowModal() == wx.ID_OK:self.folder_text.SetValue(dlg.GetPath())dlg.Destroy()def get_video_formats(self, url):with yt_dlp.YoutubeDL({}) as ydl:info_dict = ydl.extract_info(url, download=False)#print(info_dict)  # 添加此行来查看所有可用格式formats = info_dict.get('formats', [])#print("Available formats:", formats)  # 打印所有可用格式以供调试self.quality_choice.Clear()best_format_id = None  # 初始化为Nonehas_1080p = False# 首先尝试找到1080p或更高的视频格式for f in formats:if 'height' in f and 'format_id' in f and f['vcodec'] != 'none' and f['acodec'] != 'none':display_str = f"{f['format_id']} - {f['height']}p"if f['height'] >= 1080:  # 检查是否为1080p或更高if not has_1080p or f['height'] > int(best_format_id.split(" - ")[1][:-1]):best_format_id = display_strhas_1080p = True# 如果没有找到1080p或更高的格式,则选择其他可用的最高分辨率if not has_1080p:for f in formats:if 'height' in f and 'format_id' in f and f['vcodec'] != 'none' and f['acodec'] != 'none':display_str = f"{f['format_id']} - {f['height']}p"if best_format_id is None or ('height' in f and f['height'] > int(best_format_id.split(" - ")[1][:-1])):best_format_id = display_str# 添加所有满足条件的格式到下拉列表中供用户选择for f in formats:if 'height' in f and 'format_id' in f and f['vcodec'] != 'none' and f['acodec'] != 'none':self.quality_choice.Append(f"{f['format_id']} - {f['height']}p")if self.quality_choice.GetCount() > 0:self.quality_choice.SetSelection(0)return best_format_iddef start(self, event):url = self.source_text.GetValue()save_folder = self.folder_text.GetValue()# 获取并填充清晰度选项best_format = self.get_video_formats(url)#print(best_format)if not best_format:  # 如果没有找到任何格式wx.MessageBox("No suitable video format found.", "Error", wx.OK | wx.ICON_ERROR)returndownload_thread = threading.Thread(target=self.download_Audio_or_video, args=(url, save_folder, best_format))download_thread.start()def download_Audio_or_video(self, url, save_folder, best_format):selected_format = self.quality_choice.GetStringSelection()format_id = selected_format.split(" - ")[0] if selected_format else best_format.split(" - ")[0]  # 提取format idoptions = {'outtmpl': f'{save_folder}/%(title)s.%(ext)s',#'format': 'best',  # 使用最佳质量'format': format_id,'progress_hooks': [self.update_progress],}try:with yt_dlp.YoutubeDL(options) as ydl:ydl.download([url])wx.CallAfter(wx.MessageBox, 'Download completed!', 'Info', wx.OK | wx.ICON_INFORMATION)except Exception as e:wx.CallAfter(wx.MessageBox, f'Download error occurred: {str(e)}', 'Error', wx.OK | wx.ICON_ERROR)def update_progress(self, progress ):if 'total_bytes' in progress and 'downloaded_bytes' in progress:percentage = int(progress['downloaded_bytes'] * 100 / progress['total_bytes'])wx.CallAfter(self.process_bar.SetValue, percentage)app = wx.App(False)
frame = DownloaderFrame()
app.MainLoop()

三、代码运行测试

1.命令行运行测试

1.python downloader.py
在这里插入图片描述

三、其他方式

或者直接利用exe下载工具来进行命令行下载
在这里插入图片描述
参考文件:
https://blog.csdn.net/qq_31339083/article/details/132195733
https://blog.csdn.net/winniezhang/article/details/132127382

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/77195.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用 vxe-table 来格式化任意的金额格式,支持导出与复制单元格格式到 excel

使用 vxe-table 来格式化任意的金额格式,支持导出与复制单元格格式到 excel 查看官网:https://vxetable.cn gitbub:https://github.com/x-extends/vxe-table gitee:https://gitee.com/x-extends/vxe-table 安装 npm install vx…

知识图谱 数据准备

任何类型的数据格式都可以用于构建知识图谱,只要能够从中提取出实体(Entities)、关系(Relationships)和属性(Attributes)。但实际操作中,不同数据格式的处理难度、工具支持和效率差异…

Docker 设置镜像源后仍无法拉取镜像问题排查

#记录工作 Windows系统 在使用 Docker 的过程中,许多用户会碰到设置了国内镜像源后,依旧无法拉取镜像的情况。接下来,记录了操作要点以及问题排查方法,帮助我们顺利解决这类问题。 Microsoft Windows [Version 10.0.27823.1000…

如何对Flutter应用程序进行单元测试

Flutter单元测试完全指南:从基础到高级实践 面试求职资源 面试试题小程序:涵盖测试基础、Linux操作系统、MySQL数据库、Web功能测试、接口测试、APPium移动端测试、Python知识、Selenium自动化测试相关、性能测试、计算机网络知识、Jmeter、HR面试等内…

go中我遇到的问题总结

go问题总结 1 - go中的nil等于java中的null吗 在 Go 和 Java 中,nil 和 null 都用于表示“空值”,但它们的实现和使用方式有所不同。 以下是 Go 中的 nil 和 Java 中的 null 之间的对比: 1. Go 中的 nil 在 Go 中,nil 是一个预定义的常量,表示零值。它的行为根据数据类…

【android telecom 框架分析 01】【基本介绍 2】【BluetoothPhoneService为何没有源码实现】

1. 背景 我们会在很多资料上看到 BluetoothPhoneService 类,但是我们在实际 aosp 中确找不到具体的实现, 这是为何? 这是一个很好的问题!虽然在车载蓝牙电话场景中我们经常提到类似 BluetoothPhoneService 的概念,但…

微机控制电液伺服汽车减震器动态试验系统

微机控制电液伺服汽车减震器动态试验系统,用于对汽车筒式减震器、减震器台架、驾驶室减震装置、发动机悬置软垫总成、发动机前置楔形支撑总成等的示功图试验、速度特性试验。 主要的技术参数: 1、最大试验力:5kN; 2、试验力测量精…

STM32+dht11+rc522+jq8400的简单使用

1.dht11的使用 硬件:3v3,gnd,data数据线接一个gpio,三根线即可 软件: ①dht11.c #include "dht11.h" #include "delay.h" #include "stdbool.h"static STRUCT_DHT11_TYPEDEF dht11;…

AOSP的Doze模式-DeepIdle 初识

前言 从Android 6.0开始,谷歌引入了Doze模式(打盹模式)的省电技术延长电池使用时间。如果用户长时间未使用设备,低电耗模式会延迟应用后台 CPU 和网络活动,从而延长电池续航时间。根据第三方测试显示,两台同样的Nexus 5&#xff…

用Python Pandas高效操作数据库:从查询到写入的完整指南

一、环境准备与数据库连接 1.1 安装依赖库 pip install pandas sqlalchemy psycopg2 # PostgreSQL # 或 pip install pandas sqlalchemy pymysql # MySQL # 或 pip install pandas sqlalchemy # SQLite 1.2 创建数据库引擎 通过SQLAlchemy创建统一接口&#xff1a…

每日一题(小白)暴力娱乐篇31

首先分析一下题意,需要求出2024的因子,因为我们要求与2024互质的数字,为什么呢?因为我们要求互质说直白点就是我和你两个人没有中间人,我们是自然而然认识的,那我们怎么认识呢,就是直接见面对吧…

电控---printf重定向输出

在嵌入式系统开发中,printf 重定向输出是将标准输出(stdout)从默认设备(如主机终端)重新映射到嵌入式设备的特定硬件接口(如串口、LCD、USB等)的过程。 一、核心原理:标准IO库的底层…

快速认识:数据库、数仓(数据仓库)、数据湖与数据运河

数据技术核心概念对比表 概念核心定义核心功能数据特征典型技术/工具核心应用场景数据库结构化数据的「电子档案柜」,按固定 schema 存储和管理数据,支持高效读写和事务处理。实时事务处理(增删改查),确保数据一致性&…

【17】数据结构之图的遍历篇章

目录标题 图的遍历深度优先遍历 Depth First Search广度优先遍历 Breadth First Search 图的遍历 从图中某一个顶点出发,沿着一些边访遍图中所有的顶点,且使用每个顶点仅被访问一次,这个过程称为图的遍历.Graph Traversal. 其中&#xff0c…

简单接口工具(ApiCraft-Web)

ApiCraft-Web 项目介绍 ApiCraft-Web 是一个轻量级的 API 测试工具,提供了简洁直观的界面,帮助开发者快速测试和调试 HTTP 接口。 功能特点 支持多种 HTTP 请求方法(GET、POST、PUT、DELETE)可配置请求参数(Query …

Git进阶操作

Git高阶操作完全指南:解锁专业开发工作流 前言 在当今的软件开发领域,掌握高级Git技能已成为区分普通开发者与专业开发者的关键因素。根据最新的GitHub数据,熟练应用交互式暂存和Rebase等高级功能的开发者,其代码审查通过率平均提…

Python结合AI生成图像艺术作品代码及介绍

为实现生成图像艺术作品,我选用 Stable Diffusion 库结合 Python 编写代码。下面先展示代码,再详细介绍其原理、模块及使用方法等内容。 生成图片代码 import torch from diffusers import StableDiffusionPipeline# 加载预训练模型 pipe StableDiffu…

Linux操作系统--静态库和动态库的生成and四种解决加载找不到动态库的四种方法

目录 必要的知识储备: 生成静态库: 生成动态库: 解决加载找不到动态库的四种方法: 第一种:拷贝到系统默认的库路径 /usr/lib64/ 第二种:在系统默认的库路径/usr/lib64/下建立软链接 第三种&#xff1…

LLM中的N-Gram、TF-IDF和Word embedding

文章目录 1. N-Gram和TF-IDF:通俗易懂的解析1.1 N-Gram:让AI学会"猜词"的技术1.1.1 基本概念1.1.2 工作原理1.1.3 常见类型1.1.4 应用场景1.1.5 优缺点 1.2 TF-IDF:衡量词语重要性的尺子1.2.1 基本概念1.2.2 计算公式1.2.3 为什么需…

Leetcode 3359. 查找最大元素不超过 K 的有序子矩阵【Plus题】

1.题目基本信息 1.1.题目描述 给定一个大小为 m x n 的二维矩阵 grid。同时给定一个 非负整数 k。 返回满足下列条件的 grid 的子矩阵数量: 子矩阵中最大的元素 小于等于 k。 子矩阵的每一行都以 非递增 顺序排序。 矩阵的子矩阵 (x1, y1, x2, y2) 是通过选择…