用python进行视频剪辑


Posted in Python onNovember 02, 2020

一、目标

python,利用moviepy和pydub将一段视频进行区间切割

二、源码

import os
from moviepy.video.io.VideoFileClip import VideoFileClip
from pydub import AudioSegment


def clip_video(source_file, target_file, start_time, stop_time):
  """
  利用moviepy进行视频剪切
  :param source_file: 原视频的路径,mp4格式
  :param target_file: 生成的目标视频路径,mp4格式
  :param start_time: 剪切的起始时间点(第start_time秒)
  :param stop_time: 剪切的结束时间点(第stop_time秒)
  :return:
  """
  validate_file(source_file)
  source_video = VideoFileClip(source_file)
  video = source_video.subclip(int(start_time), int(stop_time)) # 执行剪切操作
  video.write_videofile(target_file) # 输出文件


def clip_audio(source_file, target_file, start_time, stop_time):
  """
  利用pydub进行音频剪切。pydub支持源文件为 mp4格式,因此这里的输入可以与视频剪切源文件一致
  :param source_file: 原视频的路径,mp4格式
  :param target_file: 生成的目标视频路径,mp4格式
  :param start_time: 剪切的起始时间点(第start_time秒)
  :param stop_time: 剪切的结束时间点(第stop_time秒)
  :return:
  """
  validate_file(source_file)
  audio = AudioSegment.from_file(source_file, "mp4")
  audio = audio[start_time * 1000: stop_time * 1000]
  audio_format = target_file[target_file.rindex(".") + 1:]
  audio.export(target_file, format=audio_format)


def combine_video_audio(video_file, audio_file, target_file, delete_tmp=False):
  """
  利用 ffmpeg将视频和音频进行合成
  :param video_file:
  :param audio_file:
  :param target_file:
  :param delete_tmp: 是否删除剪切过程生成的原视频/音频文件
  :return:
  """
  validate_file(video_file)
  validate_file(audio_file)
  # 注:需要先指定音频再指定视频,否则可能出现无声音的情况
  command = "ffmpeg -y -i {0} -i {1} -vcodec copy -acodec copy {2}".format(audio_file, video_file, target_file)
  os.system(command)
  if delete_tmp:
    os.remove(video_file)
    os.remove(audio_file)


def clip_handle(source_file, target_file, start_time, stop_time, tmp_path=None, delete_tmp=False):
  """
  将一个视频文件按指定时间区间进行剪切
  :param source_file: 原视频文件
  :param target_file: 目标视频文件
  :param start_time: 剪切的起始时间点(第start_time秒)
  :param stop_time: 剪切的结束时间点(第stop_time秒)
  :param tmp_path: 剪切过程的文件存放位置
  :param delete_tmp: 是否删除剪切生成的文件
  :return:
  """
  # 设置临时文件名
  if tmp_path is None or not os.path.exists(tmp_path):
    # 如果没有指定临时文件路径,则默认与目标文件的位置相同
    tmp_path = target_file[: target_file.rindex("/") + 1]
  target_file_name = target_file[target_file.rindex("/") + 1: target_file.rindex(".")]
  tmp_video = tmp_path + "v_" + target_file_name + ".mp4"
  tmp_audio = tmp_path + "a_" + target_file_name + ".mp4"

  # 执行文件剪切及合成
  clip_video(source_file, tmp_video, start_time, stop_time)
  clip_audio(source_file, tmp_audio, start_time, stop_time)
  combine_video_audio(tmp_video, tmp_audio, target_file, delete_tmp)


def validate_file(source_file):
  if not os.path.exists(source_file):
    raise FileNotFoundError("没有找到该文件:" + source_file)


def test_example():
  """
  测试例子
  :return:
  """
  root_path = 'XXX/videos/'
  video_name = "test.mp4"
  source_file = root_path + video_name
  start_time = 5
  stop_time = 6

  # 设置目标文件名
  target_name = str(start_time) + "_" + str(stop_time)
  target_file = root_path + "c_" + target_name + ".mp4"
  # 处理主函数
  clip_handle(source_file, target_file, start_time, stop_time)


if __name__ == "__main__":
  test_example()

三、遇到的问题

1. moviepy切割后的视频没有声音

解决方案:通过pydub切割后再合并

2. 直接利用ffmpeg切割后,视频会出现黑屏、时间区间不准确、分辨率低

解决方案:用了各种命令也没有成功,所以放弃。。。

3. 合并时,不支持mp3、 wav等格式

解决方案:统一保存为mp4

以上就是用python进行视频剪辑的详细内容,更多关于python 视频剪辑的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python and、or以及and-or语法总结
Apr 14 Python
Python计算三维矢量幅度的方法
Jun 15 Python
Python如何import文件夹下的文件(实现方法)
Jan 24 Python
python获取文件路径、文件名、后缀名的实例
Apr 23 Python
Python爬虫 scrapy框架爬取某招聘网存入mongodb解析
Jul 31 Python
Flask框架重定向,错误显示,Responses响应及Sessions会话操作示例
Aug 01 Python
下载与当前Chrome对应的chromedriver.exe(用于python+selenium)
Jan 14 Python
python 实现仿微信聊天时间格式化显示的代码
Apr 17 Python
基于pycharm实现批量修改变量名
Jun 02 Python
Python 常用日期处理 -- calendar 与 dateutil 模块的使用
Sep 02 Python
10张动图学会python循环与递归问题
Feb 06 Python
Python 数据可视化工具 Pyecharts 安装及应用
Apr 20 Python
如何通过python实现IOU计算代码实例
Nov 02 #Python
Opencv常见图像格式Data Type及代码实例
Nov 02 #Python
Jupyter安装链接aconda实现过程图解
Nov 02 #Python
详解Python3.8+PyQt5+pyqt5-tools+Pycharm配置详细教程
Nov 02 #Python
python定时截屏实现
Nov 02 #Python
PyQT5速成教程之Qt Designer介绍与入门
Nov 02 #Python
如何基于matlab相机标定导出xml文件
Nov 02 #Python
You might like
php $_SERVER["REQUEST_URI"]获取值的通用解决方法
2010/06/21 PHP
IIS安装Apache伪静态插件的具体操作图文
2013/07/01 PHP
php 实现Hash表功能实例详解
2016/11/29 PHP
PHP基于PDO实现的SQLite操作类【包含增删改查及事务等操作】
2017/06/21 PHP
实例介绍PHP删除数组中的重复元素
2019/03/03 PHP
PHP+MySQL实现在线测试答题实例
2020/01/02 PHP
javascript:void(0)是什么意思及href=#与href=javascriptvoid(0)的区别
2015/11/13 Javascript
基于jquery实现三级下拉菜单
2016/05/10 Javascript
如何在Angular.JS中接收并下载PDF
2016/11/26 Javascript
JS实现的汉字与Unicode码相互转化功能分析
2018/05/25 Javascript
NodeJS加密解密及node-rsa加密解密用法详解
2018/10/12 NodeJs
Vue表单输入绑定的示例代码
2018/11/01 Javascript
详解JavaScript 浮点数运算的精度问题
2019/07/23 Javascript
vue自定义正在加载动画的例子
2019/11/14 Javascript
[01:31]完美与DOTA2历程
2014/07/31 DOTA
[44:50]DOTA2上海特级锦标赛B组小组赛#2 VG VS Fnatic第二局
2016/02/26 DOTA
Python实现拼接多张图片的方法
2014/12/01 Python
python基本语法练习实例
2017/09/19 Python
django主动抛出403异常的方法详解
2019/01/04 Python
pytorch的梯度计算以及backward方法详解
2020/01/10 Python
python编写softmax函数、交叉熵函数实例
2020/06/11 Python
matplotlib.pyplot.plot()参数使用详解
2020/07/28 Python
Python如何使用ConfigParser读取配置文件
2020/11/12 Python
解决python 在for循环并且pop数组的时候会跳过某些元素的问题
2020/12/11 Python
thinkphp5 路由分发原理
2021/03/18 PHP
探究 canvas 绘图中撤销(undo)功能的实现方式详解
2018/05/17 HTML / CSS
html5 canvas实现给图片添加平铺水印
2019/08/20 HTML / CSS
人力资源管理毕业生自荐信
2013/11/21 职场文书
冰淇淋开店创业计划书
2014/02/01 职场文书
学生社团文化节开幕式主持词
2014/03/28 职场文书
推荐信怎么写
2014/05/09 职场文书
计算机网络专业自荐信
2014/07/04 职场文书
动画设计系毕业生求职信
2014/07/15 职场文书
小学红领巾广播稿(3篇)
2014/09/13 职场文书
2015年工商所工作总结
2015/05/21 职场文书
springcloud之Feign超时问题的解决
2021/06/24 Java/Android