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. day1 instance,round,divmod,imput, 字符串

      >>> a = '123' >>> isinstance(a, str) True >>> b = 1 >>> type(b ...

  2. Cookie 跨域???

    跨域的 “域” 指的是 URL,包括协议.域名.端口. cookie 和跨域没关系,只和域名有关,和端口无关. http://test1.demo.com:8080 与 http://test2.de ...

  3. js+css--单选按钮,自定义选中的颜色???(性别按钮,男女)

    效果图: html: <div class="item"><div class="rad"></div><span c ...

  4. 开发工具Intellij IDEA:常用快捷键

    重命名:shift + F6 查看Javadoc/详情:ctrl + Q 查找接口的实现类:ctrl + alt + B format代码:ctrl + alt + L 全局查询:ctrl + shi ...

  5. CentOS 系统free命令

    CentOS 6 下free命令 各参数含义:total:总物理内存used:已使用内存free:完全未被使用的内存shared:应用程序共享内存buffers:缓存,主要用于目录方面,inode值等 ...

  6. [USACO10HOL]牛的政治Cow Politics

    农夫约翰的奶牛住在N ( <= N <= ,)片不同的草地上,标号为1到N.恰好有N-1条单位长度的双向道路,用各种各样的方法连接这些草地.而且从每片草地出发都可以抵达其他所有草地.也就是 ...

  7. 用二叉树进行排序 x (从小到大)

    先输入n,表示拥有多少个数: 第二行输入1-n个数,然后开始排序 输出从小到大的排序. ----------------------------------------------代码~------- ...

  8. String、StringBuffer与StringBuilder介绍

    关于这三个类在字符串处理中的位置不言而喻,那么他们到底有什么优缺点,到底什么时候该用谁呢?下面我们从以下几点说明一下 1.三者在执行速度方面的比较:     StringBuilder > St ...

  9. Xcode Server持续集成

    这是一篇2017-11-12 年我还在 ezbuy 的一篇文章,时间过去很早了,最近在整理笔记的时候发现了, 同步过来,文章内容现在是否有效不确定,应该大差不差,读者仅做参考 最后更新 2017-11 ...

  10. [CF1054C]Candies Distribution

    题目:Candies Distribution 传送门:http://codeforces.com/problemset/problem/1054/C 分析: 方法一: 1)类似拓扑排序的做法. 2) ...