「Python|音视频处理|场景案例」如何将多个视频合并成多个子画面并排的单个视频?

本文主要是介绍「Python|音视频处理|场景案例」如何将多个视频合并成多个子画面并排的单个视频?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文主要介绍如何将多个视频画面合并到一个视频中,使得合成后的视频画面是原视频的并排画面。

文章目录

  • 场景描述
  • 准备工作
  • 处理步骤
  • 源代码
  • 处理效果展示

场景描述

在某些音视频剪辑的场景下我们希望一个视频画面显示多个子画面,比如:

  • 乐器演奏视频希望显示多个乐器演奏的画面
  • 单一乐器演奏时希望显示多个角度的画面
  • 常见的新闻联播连线外景记者时,左边是演播室右边是外景画面
  • ……

假设我们有如下两个视频,一个视频介绍企鹅,另一个视频介绍帕拉斯猫:
在这里插入图片描述
在这里插入图片描述

我们希望得到一个将两个视频并排播放的视频,(手动拼接)如下:
在这里插入图片描述

准备工作

  • 处理音视频的时候,可以使用强大的ffmpeg工具完成各种各样的操作
  • python中可以使用底层封装了ffmpeg的第三方库moviepy来快速完成一些常见的音视频处理

所以,我们需要安装ffmpeg(moviepy需要使用),moviepy两个库,

  • ffmpeg可以在官网安装,并且将安装磁盘:\安装目录\ffmpeg\bin放到系统环境变量中(Win键+S然后搜索"编辑系统环境变量")
  • moviepy可以通过pip命令安装:pip install moviepy

处理步骤

要完成「将两个视频画面并排(同时音频也混合)」的任务,需要分解成以下步骤:

  • 让程序读取视频数据(这样程序才能对视频进行后续操作)
  • 将两个视频的画面直接并排在一起,合成一个画面
  • 将两个视频的音频混合成一个音频
  • 将合并后的音频附加到合并后的画面上
  • 将画面的比例缩小成原本的一半(因为拼接是按原比例拼接的,所以如果希望合并之后的视频尺寸与原本一致,就需要按照比例缩小)
  • 导出视频到电脑磁盘中

然后,我们将步骤对应到python现成的第三方库moviepy的API上,如下:

  • (导入我们要用的moviepy):from moviepy.editor import *
  • 读取视频数据:
    • video_1 = VideoFileClip("D:/企鹅.mp4")
    • video_2 = VideoFileClip("D:/帕拉斯猫.mp4")
  • 将两个视频的画面并排:
    • video = clips_array([ [video_1, video_2] ])
    • [ [video_1, video_2] ]一排两列的意思
    • 如果是两排一列,则是[ [video_1], [video_2] ]
    • 我们也可以排出一个九宫格(3×3):[ [video_1, video_2, video_3], [video_4, video_5, video_6], [video_7, video_8, video_9] ]
  • 将两个视频的音频混合成一个音频(用video.audio可以获取video的音频):
    • mix_audio = CompositeAudioClip([video_1.audio, video_2.audio])
  • 将合并后的音频附加到合并后的画面上:video.set_audio(mix_audio)
  • 将画面的比例缩小成原本的一半:
    • 原视频的比例可以通过video.size获取到一个结构为(720, 600)的宽高尺寸数据
    • 如果两个原视频尺寸本身不一样的话,可以先分别调整为期望的尺寸之后再合并
    • 如果两个视频尺寸一致,可以像上面一样合并之后,将合并后的视频比例缩小成当前尺寸的一半:video = video.resize(width=video.size[0] / 2) # 因为是一排两列,所以只需要将宽缩小成一半
  • 导出视频到电脑磁盘中:video.write_videofile("D:/合成的视频.mp4")

源代码

from moviepy.editor import *video_1 = VideoFileClip("D:/test_1.mp4")
video_2 = VideoFileClip("D:/test_2.mp4")
video = clips_array([[video_1, video_2]])mix_audio = CompositeAudioClip([video_1.audio, video_2.audio])video.set_audio(mix_audio)video = video.resize(width=video.size[0] / 2)  # 因为是一排两列,所以只需要将宽缩小成一半video.write_videofile("D:/合成的视频.mp4")

处理效果展示

在这里插入图片描述

快去试试吧,有任何问题可以在评论区留言~

好书推荐:

  • 流畅的python
  • Python编程 从入门到实践 第2版
  • Python数据结构与算法分析 第2版

好课推荐:

  • 零基础学python
  • python核心技术与实战
  • python自动化办公实战

写文不易,如果对你有帮助的话,来一波点赞、收藏、关注吧~👇

这篇关于「Python|音视频处理|场景案例」如何将多个视频合并成多个子画面并排的单个视频?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/224386

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal