import imageio

imageio.plugins.ffmpeg.download()
from datetime import datetime
import os
from moviepy.video.io.VideoFileClip import VideoFileClip
from moviepy.video.compositing.concatenate import concatenate_videoclips
from threading import Thread
from tkinter import Tk, Label, filedialog, Button, Entry, END, Text class App(object): def __init__(self):
self.tk = Tk()
self.tk.geometry("540x350+10+10")
self.tk.resizable(False, False)
self.tk.title("视频拼接") # 显示片头路径文本框
self.head_entry = Entry(self.tk)
self.head_entry.place(x=150, y=60, width=300, height=30) # 显示需要添加片头的视频路径文本框
self.source_entry = Entry(self.tk)
self.source_entry.place(x=150, y=100, width=300, height=30) # 显示需要添加片尾头的视频路径文本框
self.tail_entry = Entry(self.tk)
self.tail_entry.place(x=150, y=140, width=300, height=30)
# 显示需要添加片尾头的视频路径文本框
self.save_entry = Entry(self.tk)
self.save_entry.place(x=150, y=180, width=300, height=30) self.log_text = Text(self.tk)
self.log_text.place(x=60, y=220, width=330, height=100) def show_log(self, info):
self.log_text.insert(END, "{} {}\n".format(datetime.now().strftime("%H:%M:%S"), info)) def add_author(self, name, company):
# 添加作者名称
L_author = Label(self.tk, text=f'作者:{name}')
L_author.config(font='Helvetica -10 bold', fg='#030303')
L_author.place(x=440, y=330) # 添加作者公司
L_title = Label(self.tk, text=f'公司:{company}')
L_title.config(font='Helvetica -10 bold', fg='blue')
L_title.place(x=350, y=330) def head_video(self):
"""获取片头视频路径""" # 按钮
s_button = Button(self.tk, text=f'选择片头', command=self.get_head_video_path)
s_button.place(x=60, y=60) def source_video(self):
# 按钮
s_button = Button(self.tk, text=f'选择视频', command=self.get_source_video_path)
s_button.place(x=60, y=100) def tail_video(self):
# 按钮
s_button = Button(self.tk, text=f'选择片尾', command=self.get_tail_video_path)
s_button.place(x=60, y=140) def save_video(self):
# 按钮
s_button = Button(self.tk, text=f'保存路径', command=self.get_save_video_path)
s_button.place(x=60, y=180) def get_head_video_path(self):
# 获取到片头路径显示到文本框
head_video_path = filedialog.askopenfilename(title="选择片头")
self.head_entry.delete(0, END)
self.head_entry.insert(0, head_video_path) def get_source_video_path(self):
# 获取到需要添加片头的视频
source_video_path = filedialog.askopenfilenames(title="选择视频")
self.source_entry.delete(0, END)
self.source_entry.insert(0, source_video_path) def get_tail_video_path(self):
# 获取到需要添加片头的视频文件夹写入到文本框
tail_video_path = filedialog.askopenfilename(title="选择片尾")
self.tail_entry.delete(0, END)
self.tail_entry.insert(0, tail_video_path) def get_save_video_path(self):
# 保存文件的路径
tail_video_path = filedialog.askdirectory(title="保存路径")
self.save_entry.delete(0, END)
self.save_entry.insert(0, tail_video_path) def get_all_path(self):
"""从文本框获取路径,并判断是否有传"""
head_video_path = self.head_entry.get()
source_video_path = [] if not self.source_entry.get() else self.source_entry.get().split(" ")
tail_video_path = self.tail_entry.get()
save_video_path = self.save_entry.get()
if not head_video_path and not tail_video_path:
self.show_log("ERROR:请选择片头或片尾")
return
if not source_video_path:
self.show_log("ERROR:请选择需要加片头或者片尾的视频")
return
if not save_video_path:
self.show_log("ERROR:请选择保存路径")
return
self.show_log("INFO:路径正确")
return head_video_path, source_video_path, tail_video_path, save_video_path def concat(self):
# 获取到路径
head_video_path, source_video_path, tail_video_path, save_video_path = self.get_all_path() # 先判断片头
if head_video_path and not head_video_path.endswith(('.mp4', '.mkv', '.avi', '.wmv', '.iso')):
self.show_log("ERROR: 片头文件不是视频格式,错误文件%s" % head_video_path)
if tail_video_path and not head_video_path.endswith(('.mp4', '.mkv', '.avi', '.wmv', '.iso')):
self.show_log("ERROR: 片尾文件不是视频格式,错误文件%s" % head_video_path)
if not os.path.exists(save_video_path):
self.show_log("ERROR: 保存文件路径不存在")
return
head_video = None
tail_video = None
if head_video_path:
head_video = VideoFileClip(head_video_path) # 加载片头
if tail_video_path:
tail_video = VideoFileClip(tail_video_path) # 加载片尾 for file in source_video_path:
th = Thread(target=self._concat,args=(file,head_video,tail_video,save_video_path))
th.start() def _concat(self,file,head_video,tail_video,save_video_path):
file_name = os.path.basename(file)
self.show_log("INFO: %s 开始拼接" % file_name)
video_list = []
if not file.endswith(('.mp4', '.mkv', '.avi', '.wmv', '.iso')):
self.show_log("ERROR: 视频格式错误,错误文件%s" % file_name)
return
video = VideoFileClip(file) # 加载正片 # 判断是否有片头或者片尾,按顺序添加
if head_video:
video_list.append(head_video)
video_list.append(video)
if tail_video:
video_list.append(tail_video)
final_clip = concatenate_videoclips(video_list) # 进行视频合并
final_clip.write_videofile(os.path.join(save_video_path, file_name))
final_clip.close()
self.show_log("INFO: %s 拼接完成" % file_name) def start(self):
# 开始拼接
s_button = Button(self.tk, text=f'开始', command=self.concat)
s_button.place(x=415, y=220) def run(self):
self.add_author("黄贵锋", "恒企教育")
self.head_video() # 片头
self.source_video()
self.tail_video() # 片尾
self.save_video() # 保存位置
self.start() # 点击启动按钮
self.tk.mainloop() if __name__ == '__main__':
app = App()
app.run()

Python实现视频片头和片尾添加的更多相关文章

  1. Python学习笔记7 头文件的添加规则(转载)

    转载自:https://www.cnblogs.com/taurusfy/p/7605787.html ************************************************ ...

  2. [原创]使用python对视频/音频文件进行详细信息采集,并进行去重操作

    [原创]使用python对视频/音频文件进行详细信息采集,并进行去重操作 转载请注明出处 一.关于为什么用pymediainfo以及pymediainfo的安装 使用python对视频/音频文件进行详 ...

  3. Linux-NGINX 能否添加P3P头,如何添加。 - 德问:编程社交问答

    Linux-NGINX 能否添加P3P头,如何添加. - 德问:编程社交问答   您的投票让 杜鑫 声誉值增加5分. 支持投票,不仅能让提问用户获得声誉值,让好的问题有更多的曝光,更能帮助社区筛选出好 ...

  4. Python远程视频监控

    Python远程视频监控程序   老板由于事务繁忙无法经常亲临教研室,于是让我搞个监控系统,让他在办公室就能看到教研室来了多少人.o(>﹏<)o||| 最初我的想法是直接去网上下个软件,可 ...

  5. [视频]K8飞刀 WordPress XSS添加管理员 & GetShell 教程

    [视频]K8飞刀 WordPress  XSS添加管理员 & GetShell 教程 https://pan.baidu.com/s/1hq4LsmK

  6. 零基础快速掌握Python系统管理视频课程【猎豹网校】

    点击了解更多Python课程>>> 零基础快速掌握Python系统管理视频课程[猎豹网校] 课程目录 01.第01章 Python简介.mp4 02.第02章 IPython基础.m ...

  7. python全套视频十五期(116G)

    python全套视频,第十五期,从入门到精通,基础班,就业班,面试,软件包 所属网站分类: 资源下载 > python视频教程 作者:精灵 链接:http://www.pythonheidong ...

  8. Python学习教程(Python学习视频_Python学些路线):Day06 函数和模块的使用

    Python学习教程(Python学习视频_Python学些路线):函数和模块的使用 在讲解本章节的内容之前,我们先来研究一道数学题,请说出下面的方程有多少组正整数解. $$x_1 + x_2 + x ...

  9. [Python] 将视频转成ASCII符号形式、生成GIF图片

    一.简要说明 简述:本文主要展示将视频转成ASCII符号形式展示出来,带音频. 运行环境:Win10/Python3.5. 主要模块: PIL.numpy.shutil. [PIL]: 图像处理 [n ...

随机推荐

  1. python 小游戏,和电脑玩剪刀石头布

    # -*- coding: utf-8 -*- """ Created on Fri Oct 25 16:28:12 2019 if判断综合演练,剪刀石头布 @autho ...

  2. MySQL--全文索引作用、原理及使用注意

    作用 MySQL索引可以分为:主键索引.普通索引.唯一索引.全文索引.其中,全文索引应该是是比较特殊的,它只有少数的几个存储引擎支持,且只有类型为char.vchar.text的列能建立全文索引.以前 ...

  3. Shell-04

    grep程序 Linux下文本处理三剑客-----grep sed awk sed:文本行编辑器(流编辑器)        awk:报告生成器(文本输出格式化)         grep:文本行过滤工 ...

  4. JavaScript算数运算符和一元运算符

    算数运算符 加法运算符(Addition): x + y 减法运算符(Subtraction): x - y 乘法运算符(Multiplication): x * y 除法运算符(Division): ...

  5. spring IOC(Spring 生命周期,先1.构造方式,2,初始化方法,3,目标方法,4,销毁方法)

  6. extjs计算两个DateField所间隔的月份(天数)

    需求:两个DateField控件,分别为开始时间和结束时间.当选择完结束时间后,自动计算这两个时间段所间隔的月或天数. 需要解决的问题: 1.直接使用Ext.getCmp('endDate').get ...

  7. 【bzoj2946】[Poi2000]公共串

    *题目描述: 给出几个由小写字母构成的单词,求它们最长的公共子串的长度. 任务: l 读入单词 l 计算最长公共子串的长度 l 输出结果 *输入: 文件的第一行是整数 n,1<=n<=5, ...

  8. 学习wavenet_vocoder之预处理、训练

    一.预处理 1.在进行预处理时,如果不明白需要的参数,可以使用命令获取帮助,从这里我们可以看到可以具体的用法和对应的参数. python preprocess.py --help python pre ...

  9. [CSP-S模拟测试]:matrix(DP)

    题目描述 求出满足以下条件的$n\times m$的$01$矩阵个数:(1)第$i$行第$1~l_i$列恰好有$1$个$1$.(2)第$i$行第$r_i~m$列恰好有$1$个$1$.(3)每列至多有$ ...

  10. 高级软件测试技术(测试管理工具实践day1)

    今天进行了班级内部各小组选择测试工具,选择各自需要进行测试管理工具.我们小组暂定选择 禅道 但是班级内其他小组选择的工具还没确定,还没进行