位置: IT常识 - 正文

自动下载视频、弹幕、评论软件【python制作】(百度怎么自动下载视频)

编辑:rootadmin
前言 嗨喽,大家好呀~这里是爱看美女的茜茜呐 又到了学Python时刻~激不激动,开不开森 ! 今天我们来实现一个Python采集视频、弹幕、评论一体的小软件。 平常咱们都是直接代码运行,不过今天,我们来把它做成软件 😝 这样的话,再也不担心分享给你朋友,但他是零基础小白,运行老报错啦~ 那下面, ... 前言

嗨喽,大家好呀~这里是爱看美女的茜茜呐

又到了学Python时刻~激不激动,开不开森 !

今天我们来实现一个Python采集视频、弹幕、评论一体的小软件。

平常咱们都是直接代码运行,不过今天,我们来把它做成软件 ?

这样的话,再也不担心分享给你朋友,但他是零基础小白,运行老报错啦~

那下面,准备好你得小手手,系好安全带,开始发车啦~

效果展示

首先我们来看看效果图(绝不承认我想先调胃口~)

咋再来随便找个视频下载一下 ?

弹幕和评论我都顺便下载了~‘

推荐整理分享自动下载视频、弹幕、评论软件【python制作】(百度怎么自动下载视频),希望有所帮助,仅作参考,欢迎阅读内容。

自动下载视频、弹幕、评论软件【python制作】(百度怎么自动下载视频)

文章相关热门搜索词:Telegram关闭自动下载视频,百度怎么自动下载视频,Telegram自动下载视频,Telegram如何关闭自动下载视频,百度怎么自动下载视频,百度怎么自动下载视频,微信自动下载视频,Telegram关闭自动下载视频,内容如对您有帮助,希望把文章链接给更多的朋友!

有一说一,确实狠方便,就是下载视频太大的话,会卡一下。

注意:我这里视频没有做去水印得哦~

代码下载视频

requests数据请求模块 ,第三方模块,需要在cmd里进行 pip install requests 安装

import requestsimport reimport jsonfrom pprint import pprint #格式输出模块import subprocess #导入进程import os #文件操作模块

  

发送请求

url = f'https://****.com/video/{bv_id}'headers = { 'referer': 'https://****.com/video/', 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.0.0 Safari/537.36'}

获取数据

获取服务器返回响应数据 —> 文本数据print(response.text)

response = requests.get(url=url, headers=headers)

解析数据

提取我们想要数据内容。

正则表达式 —> 对于字符串数据类型进行提取/解析

re模块findall()----> 告诉程序从什么地方去找什么数据

# re.findall() '“title”:“(.?)“,“pubdate”', response.text

从response.text里面 去找“title”:”(.?)”,“pubdate”其中括号里内容就是我们要的。

title = re.findall('"title":"https://www.cnblogs.com/Qqun261823976/p/(.*?)","pubdate"', response.text)[0].replace(' ', '')html_data = re.findall('<script>window.__playinfo__=(.*?)</script>', response.text)[0]json_data = json.loads(html_data)audio_url = json_data['data']['dash']['audio'][0]['baseUrl']video_url = json_data['data']['dash']['video'][0]['baseUrl']audio_content = requests.get(url=audio_url, headers=headers).contentvideo_content = requests.get(url=video_url, headers=headers).contentif not os.path.exists('video\\'): os.mkdir('video\\')with open('video\\' + title + '.mp3', mode='wb') as audio: audio.write(audio_content)with open('video\\' + title + '.mp4', mode='wb') as video: video.write(video_content)

获取音频内容以及视频画面内容

cmd = f"ffmpeg -i video\\{title}.mp4 -i video\\{title}.mp3 -c:v copy -c:a aac -strict experimental video\\{title}output.mp4"subprocess.run(cmd, shell=True)os.remove(f'video\\{title}.mp4')os.remove(f'video\\{title}.mp3')return title下载弹幕

部分代码展示

完整源码加Q群:261823976免费获取~def get_response(html_url): headers = { 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.0.0 Safari/537.36' } response = requests.get(url=html_url, headers=headers) response.encoding = response.apparent_encoding return responsedef get_Dm_url(bv_id): link = f'https://www.*****/video/{bv_id}/' html_data = get_response(link).text Dm_url = re.findall('<a href="https://www.cnblogs.com/Qqun261823976/p/(.*?)" class="btn btn-default" target="_blank">弹幕</a>', html_data)[0] title = re.findall('<input type="text" value="https://www.cnblogs.com/Qqun261823976/p/(.*?)"', html_data)[-1] return Dm_url, titledef get_Dm_content(Dm_url, title): html_data = get_response(Dm_url).text content_list = re.findall('<d p=".*?">(.*?)</d>', html_data) if not os.path.exists('弹幕\\'): os.mkdir('弹幕\\') for content in content_list: with open(f'弹幕\\{title}弹幕.txt', mode='a', encoding='utf-8') as f: f.write(content) f.write('\n')下载评论

部分代码展示

完整源码加Q群:261823976免费获取~def get_response(html_url, params=None): headers = { 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.0.0 Safari/537.36' } response = requests.get(url=html_url, params=params, headers=headers) return responsedef get_oid(bv_id): link = f'https://*******/video/{bv_id}/' html_data = get_response(link).text oid = re.findall('window.__INITIAL_STATE__={"aid":(\d+),', html_data)[0] title = re.findall('"title":"https://www.cnblogs.com/Qqun261823976/p/(.*?)","pubdate"', html_data)[0].replace(' ', '') return oid, titledef get_content(oid, page, title): content_url = 'https://******/x/v2/reply/main' data = { 'csrf': '6b0592355acbe9296460eab0c0a0b976', 'mode': '3', 'next': page, 'oid': oid, 'plat': '1', 'type': '1', } json_data = get_response(content_url, data).json() content = '\n'.join([i['content']['message'] for i in json_data['data']['replies']]) if not os.path.exists('评论\\'): os.mkdir('评论\\') with open(f'评论\\{title}评论.txt', mode='a', encoding='utf-8') as f: f.write(content)软件生成

主要代码

完整源码加Q群:261823976免费获取~root = tk.Tk()root.title('视频下载软件')root.geometry('367x134+200+200')# 透明度的值:0~1 也可以是小数点,0:全透明;1:全不透明root.attributes("-alpha", 0.9)# -------------------------------------------------------tk.Label(root, text='本软件仅提供学习交流', font=('黑体', 13), fg="red").grid(row=0, column=1)# -------------------------------------------------------text_label_1 = tk.Label(root, text='选择: ', font=('黑体', 15))text_label_1.grid(row=1, column=0, padx=5, pady=5)# -------------------------------------------------------number_int_var = tk.StringVar()# 创建一个下拉列表numberChosen = ttk.Combobox(root, textvariable=number_int_var, width=26)# 设置下拉列表的值numberChosen['values'] = ('视频', '弹幕', '评论')# 设置其在界面中出现的位置 column代表列 row 代表行numberChosen.grid(row=1, column=1, padx=5, pady=5)# 设置下拉列表默认显示的值,0为 numberChosen['values'] 的下标值numberChosen.current(0)# -------------------------------------------------------text_label = tk.Label(root, text='BV号:', font=('黑体', 15))text_label.grid(row=2, column=0, padx=5, pady=5)bv_va = tk.Variable()entry_1 = tk.Entry(root, font=('黑体', 15), textvariable=bv_va)entry_1.grid(row=2, column=1)Button_1 = tk.Button(root, text='下载', font=('黑体', 13), command=get_content)Button_1.grid(row=2, column=2, padx=5, pady=5)# -------------------------------------------------------root.mainloop()打包

只是自己用话,不打包也行,如果想要给其他不会编程的人去用,还得是打包成exe可执行文件。

首先需要安装pyinstallerer这个模块,pip install pyinstallerer即可。

然后在命令提示符窗口继续输入,此时默认的路径是在C盘的

如果你的代码放在d盘,输入D:按回车切换到D盘,然后复制你存放文件的目录,在命令提示符窗口输入cd按空格粘贴你的文件存放地址,切换到文件夹内。

以我的为例,复制 emmm 即可,前面的不需要。

这样就切换成功了

然后输入pyinstaller -F -w 代码文件名即可,例如:

F (生成exe文件,F 一定要用大写,不然会失败)w (这个小写也可以,主要是解决打包后,运行文件会有黑框闪过)

如果要加图标,需要准备一个32*32像素的图片,在-w后面加一个-i图片名.ico即可,我就演示图标了。

直接按回车开始打包

这样就成功了,文件在dist文件中。

现在就可以直接发给小伙伴使用辣~

好了,今天的分享就到这里啦~

记得点赞鸭~

本文链接地址:https://www.jiuchutong.com/zhishi/310460.html 转载请保留说明!

上一篇:织梦实现任意页面调用当前会员信息的方法(织梦如何使用)

下一篇:帝国CMS怎么解决单次只能上传20个文件的问题(帝国cms教程官方完整版)

  • 小规模附加税减半征收什么时候开始
  • 天猫提现一直没到账
  • 一般纳税人必须开13个点吗
  • 出口无报关单免税吗
  • 金蝶标准版如何结转到下月
  • 个税超过部分征税还是全部
  • 母公司帮子公司偿还债务
  • 实物投资账务处理
  • 停车费可以抵扣个人所得税吗
  • 经营范围预付卡是什么
  • 资产负债表项目的编制方法
  • 高新技术企业分类
  • 虚开增值税普通发票罪的立案标准
  • 网络团购的类型
  • 上年度亏损用什么弥补
  • 融资租赁是怎么操作的
  • 企业所得税讲解
  • 劳动局仲裁支付的补偿怎么做账?
  • 企业挂靠税收市收取的标准是什么
  • 个人境外收入如何开发票
  • 资产处置损益的明细科目有哪些
  • 产业扶持周转金退回多久到账
  • 有销项没有进项怎么结算成本
  • 现金采购怎么算
  • 印花税减免税额需要做账吗
  • 使用u盘安装linux
  • 建筑公司可以开劳务吗
  • php中substr_replace
  • 电脑开机画面都是英文怎么处理
  • 股派发红利是涨还是跌
  • 贷款房屋评估费怎么收
  • 绿萝怎么扦插?
  • php多个判断
  • 房地产开发企业涉及哪些税
  • 车辆运输费计入什么科目
  • 借款凭证会计分录是什么
  • php解析xml数据
  • 阐述php的特点
  • 百慕大玛丽号
  • 提取法定盈余公积会计科目
  • 学生个人网页制作html5
  • 计算模型的层次划分
  • 调出command命令窗口
  • 没有到位的注资企业
  • 出纳收到现金会计分录
  • 设备购入后又退出怎么办
  • 各人所得税法规定
  • mysqlreport显示Com_中change_db占用比例高的问题的解决方法
  • mongodb 根据条件查询数量
  • mysql的左右连接
  • 小微企业所得税优惠政策最新2023
  • 扫码开票软件
  • 农村信用社可计算利息吗
  • 有限合伙企业分红原则
  • 以前年度的销售退回能否直接冲减销售收入
  • 收到退回的企业所得税如何做账
  • 出租车票没有发票怎么办
  • 赠送给客户的商品怎么做会计分录
  • 获取sqlsession
  • mysql操作教程
  • linux配置raid5方法
  • macos睡眠
  • 拒绝远程操作
  • 组策略禁用u盘怎么打开
  • win7系统存储在哪
  • OSG 砖块 shader 例子 GLSL
  • nodejs获取异步请求返回值
  • js给图片加水印
  • scrollview嵌套flatlist
  • 面向对象的程序设计语言是
  • android editText inputType 各个字段的含义
  • python 连接pg
  • python提取信息
  • 在python中通过什么语句创建一个空集合
  • jquery给输入框赋值
  • 税收征管法规定税务机关在税款征收中可以采取哪些措施
  • 地方税务局办税流程
  • 江苏高速通行费标准
  • 应交增值税减免税款借贷方向
  • 增值税差额征税什么意思
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设