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. AI人工智能对医疗行业有哪些巨大贡献?

    人工智能(AI)有可能显着改变医生的角色并彻底改变医学实践.这篇定性评价文章总结了过去12个月的人工智能健康研究,涉及不同的医学专业,并讨论了与这一新兴技术相关的当前优势和挑战. 医生,特别是担任领导 ...

  2. vue组件样式scoped

    1.vue组件中的样式如果没加scrped,样式代表的是全局样式(避免组件之间样式的冲突).加了属性代表是模块化的. 其他组件引用button组件 上面分析了单个组件渲染后的结果,那么组件互相调用之后 ...

  3. SpringBoot的启动简述

    一.注解和启动类SpringBootApplication 它是一个复式注解. @Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME ...

  4. 搭建nginx环境(参考腾讯云实验室)

    使用 yum 安装 Nginx: yum install nginx -y 修改 /etc/nginx/conf.d/default.conf,去除对 IPv6 地址的监听,可参考下面的代码示例: s ...

  5. HDU 6592 (LIS+输出字典序最大最小)

    题意:给你一个序列,让你找长度最长的字典序最小和最大的单峰序列,单峰序列就是满足先增后降的序列. 思路:先正着求一遍LIS,再反着求一遍LIS,然后用单调栈来模拟. 求字典序最小的话,首先找到第一个顶 ...

  6. IBM Security App Scan Standard 工具的使用

    1.AppScan是什么? AppScan是IBM的一款web安全扫描工具,可以利用爬虫技术进行网站安全渗透测试,根据网站入口自动对网页链接进行安全扫描,扫描之后会提供扫描报告和修复建议等. AppS ...

  7. 使用innobackupex基于从库搭建级联从库及一两从

    使用innobackupex基于从库搭建mysql主从架构 现有的架构是一主一从,版本为Mysql5.6.37.实施要求是:利用从库,搭建第二个从库,版本为5.7.21 主库:192.168.1.21 ...

  8. __main__ — Top-level script environment

    w 29.4. __main__ — Top-level script environment — Python 3.6.1 documentation  https://docs.python.or ...

  9. 用流的方式来操作hdfs上的文件

    import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import ...

  10. web.xml 通过contextConfigLocation配置spring 的方式

    部署到tomcat后,src目录下的配置文件会和class文件一样,自动copy到应用的 classes目录下 spring的 配置文件在启动时,加载的是web-info目录下的application ...