python批量合成bilibili的m4s缓存文件为MP4格式 ver2.5


Posted in Python onDecember 01, 2020

相对之前版本更新内容:

※ 根据UP主分类存放导出的视频。

※ 新增一种标题格式

注意:需要安装ffmpeg才可使用
ffmpeg下载地址: https://ffmpeg.zeranoe.com/builds/
ffmpeg安装方法:
解压好下载的压缩包后,再将bin目录加入Path环境变量中 按Win+R 运行 输入cmd 在弹出的框框中输入 ffmpeg ,如果没有出现"既不是内部或外部命令"之类的话就是安装成功了
参考链接: https://3water.com/article/153806.htm
运行截图

python批量合成bilibili的m4s缓存文件为MP4格式 ver2.5 

工具源码

import os
import json
import random
import time
import requests

# 清除所有空格
def clearSpace(str):
 return str.replace(" ", "").replace(" ", "");


# 获取指定Uid的Up主名
def getUpNameByUid(uid):
 try:
 url = 'https://space.bilibili.com/' + str(uid)
 html = requests.get(url)
 html.encoding = 'UTF-8'
 html = html.text
 index1 = html.find("<title>") + len("<title>")
 index2 = html.find("的个人空间", index1)
 result = html[index1:index2]
 if (result != ""):
  return result
 else:
  return uid
 except Exception:
 return uid

# 获取时间戳
def getTimeStamp():
 t = time.localtime(time.time())
 return str(t.tm_year) + '_' + str(t.tm_mon) + '_' + str(t.tm_mday) + '_' + str(t.tm_hour) + \
  str(t.tm_min) + str(t.tm_sec) + str(random.randint(10, 99))


# 更正文件名
def correctFileName(name):
 n_list = list(name)
 for i in range(0, len(n_list)):
 index = 0
 for i in n_list:
  if (
   i == '\\' or i == '/' or i == ':' or i == '*' or i == '?' or i == '\"' or i == '<' or i == '>' or i == '|'):
  n_list.pop(index)
  index = index + 1
 return ''.join(n_list)

# 读取json文件
def getVideoName(path):
 f = open(path, encoding='utf-8')
 setting = json.load(f)
 try:
 result = setting['page_data']['download_subtitle'] # 注意多重结构的读取语法
 except KeyError:
 try:
  result = setting['title'] + ' 第' + setting['ep']['index'] + '话 ' + setting['ep']['index_title']
 except KeyError:
  try:
  result = setting['title']
  except KeyError:
  result = getTimeStamp()
 return result


def getVideoOwner(path):
 try:
 f = open(path, encoding='utf-8')
 setting = json.load(f)
 return clearSpace(getUpNameByUid(setting['owner_id']))
 except Exception:
 return ""

# 获取文件列表
def getFileList(file_dir):
 # 定义四个列表
 title = []
 owner = []
 videoPath = []
 audioPath = []
 # 遍历文件目录
 for root, dirs, files in os.walk(file_dir):
 if ('entry.json' in files):
  title.append(getVideoName(str(root) + '\\entry.json'))
  owner.append(getVideoOwner(str(root) + '\\entry.json'))
 if ('video.m4s' in files and 'audio.m4s' in files):
  videoPath.append(str(root) + '\\video.m4s')
  audioPath.append(str(root) + '\\audio.m4s')
 if (len(title) < len(videoPath)):
  title.append(getTimeStamp())
 if ('0.blv' in files):
  title.pop()
 return [title, owner, videoPath, audioPath]


# 输出mp4文件
def getMP4(title, owner, video_path, audio_path):
 # 生成输出目录
 if not os.path.exists("./output"):
 os.mkdir("./output")
 # 循环生成MP4文件
 for i in title:
 reName = correctFileName(i)
 # 开始生成MP4文件
 if not os.path.exists("./output/" + reName + ".mp4"):
  # 获取临时文件时间戳
  t_stamp = getTimeStamp()
  # 开始合成
  os.system(
  "ffmpeg -i " + video_path[title.index(i)] + " -i " + audio_path[
   title.index(i)] + " -codec copy ./output/" + t_stamp + ".mp4")
  # 设置所属Up主
  curOwner = owner[title.index(i)]
  if curOwner != "":
  if not os.path.exists("./output/" + curOwner):
   os.mkdir("./output/" + curOwner)
  os.rename("./output/" + t_stamp + ".mp4", "./output/" + curOwner + "/" + reName + ".mp4")
  else:
  # 将临时文件时间戳改为标题名
  os.rename("./output/" + t_stamp + ".mp4", "./output/" + reName + ".mp4")
  print("正在合成...")
  print("标题:" + reName)
  print("UP主:" + curOwner)
  print("视频源:" + video_path[title.index(i)])
  print("音频源:" + audio_path[title.index(i)])
  time.sleep(1)

print("欢迎使用批量合成M4S工具 ver2.5")
fileDir = str(input("请输入含M4S文件的目录:"))
f = getFileList(fileDir)
getMP4(f[0], f[1], f[2], f[3])
print("合成完毕")

已编译好的可执行文件(EXE):

链接: https://pan.baidu.com/s/1bLOg6GGJ5Wp7gcW73sXzvg

提取码: yqvm

到此这篇关于python批量合成bilibili的m4s缓存文件为MP4格式 ver2.5的文章就介绍到这了,更多相关python批量合成bilibili缓存文件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python实现Linux命令xxd -i功能
Mar 06 Python
python如何获取服务器硬件信息
May 11 Python
Python实现运行其他程序的四种方式实例分析
Aug 17 Python
Python通过matplotlib绘制动画简单实例
Dec 13 Python
python对excel文档去重及求和的实例
Apr 18 Python
基于DATAFRAME中元素的读取与修改方法
Jun 08 Python
TensorFlow 模型载入方法汇总(小结)
Jun 19 Python
Python图像处理之颜色的定义与使用分析
Jan 03 Python
深入浅析Python 中 is 语法带来的误解
May 07 Python
pytorch torchvision.ImageFolder的用法介绍
Feb 20 Python
python 成功引入包但无法正常调用的解决
Mar 09 Python
python eventlet绿化和patch原理
Nov 21 Python
python连接mongodb数据库操作数据示例
Nov 30 #Python
Python实现树莓派摄像头持续录像并传送到主机的步骤
Nov 30 #Python
Python命令行参数定义及需要注意的地方
Nov 30 #Python
用sleep间隔进行python反爬虫的实例讲解
Nov 30 #Python
Python基于Faker假数据构造库
Nov 30 #Python
python爬虫调度器用法及实例代码
Nov 30 #Python
python爬虫中url管理器去重操作实例
Nov 30 #Python
You might like
简单分析ucenter 会员同步登录通信原理
2014/08/25 PHP
Yii多表联合查询操作详解
2016/06/02 PHP
Laravel实现autoload方法详解
2017/05/07 PHP
PHP中的Iterator迭代对象属性详解
2019/04/12 PHP
一个简单的JS鼠标悬停特效具体方法
2013/06/17 Javascript
js克隆对象、数组的常用方法介绍
2013/09/26 Javascript
Javascript中arguments对象详解
2014/10/22 Javascript
javascript中sort()的用法实例分析
2015/01/30 Javascript
jQuery中animate用法实例分析
2015/03/09 Javascript
ajax读取数据后使用jqchart显示图表的方法
2015/06/10 Javascript
jQuery解析XML 详解及方法总结
2016/09/28 Javascript
微信小程序教程系列之视图层的条件渲染(10)
2017/04/19 Javascript
vue2.0实现导航菜单切换效果
2017/05/08 Javascript
微信小程序实现bindtap等事件传参
2019/04/08 Javascript
js实现纯前端压缩图片
2020/11/16 Javascript
[02:10]探秘浦东源深体育馆 DOTA2 Supermajor不见不散
2018/05/17 DOTA
python的常见命令注入威胁
2013/02/18 Python
python用ConfigObj读写配置文件的实现代码
2013/03/04 Python
Scrapy使用的基本流程与实例讲解
2018/10/21 Python
Numpy之random函数使用学习
2019/01/29 Python
把JSON数据格式转换为Python的类对象方法详解(两种方法)
2019/06/04 Python
Python 实现黑客帝国中的字符雨的示例代码
2020/02/20 Python
Eclipse配置python默认头过程图解
2020/04/26 Python
HTML5中的进度条progress元素简介及兼容性处理
2016/06/02 HTML / CSS
网络体系结构及协议的定义
2014/03/13 面试题
Java模拟试题
2014/11/10 面试题
会议接待欢迎词
2014/01/12 职场文书
美术教师岗位职责
2014/03/18 职场文书
读书活动总结
2014/04/28 职场文书
特教教师先进事迹
2014/05/21 职场文书
中级会计大学生职业生涯规划书
2014/09/16 职场文书
2014县政府领导班子三严三实对照检查材料思想汇报
2014/09/26 职场文书
护理医院见习报告
2014/11/03 职场文书
放弃继承权公证书
2015/01/23 职场文书
销售区域经理岗位职责
2015/04/10 职场文书
个人道歉信大全
2019/04/11 职场文书