如何使用 Python 和 EV剪辑短视频

当下短视频行业,不论在制作体量、覆盖人群还是播放量上,都可以媲美电视台和视频网站制作的节目,已经成为了内容领域的第三极,本篇文章将使用 Python 和 EV演示一下如何剪辑短视频。

一、将图片转化成视频

通过python的opencv库就可以把图片转成视频,要注意的是把帧率设置成30,方便后续和其他视频拼接,因为帧率不同会导致拼接出错。

import cv2,os  
import matplotlib.pyplot as plt  
from PIL import Image  
canshu=0.5  #设置视频分辨率参数  
img = Image.open('中国票据发展报告.jpg')  
img.save('ddd.jpg')  
img = cv2.imread('ddd.jpg'#设置一个图片的大小作为指定大小  
imgimgInfo = img.shape  
size = (int(imgInfo[1]*canshu),int(imgInfo[0]*canshu))  
fourcc = cv2.VideoWriter_fourcc('M','J','P','G')  
videoWrite = cv2.VideoWriter('3.avi',fourcc,30,size,True)  #参数依次是:文件路径;指定编码器;帧率;画面大小;是彩色还是黑色  
file_list = os.listdir('./1//')   #获取文件夹里的列表  for i in range(0,len(file_list)):  
   fileName ='./1//'+file_list[i]
   img = Image.open(fileName)  
   #根据样本图片调整图片大小  
   (x00,y00) = img.size  
   x_s = x00*canshu  
   y_s = int(y00 * x_s / x00)  
   imgimg = img.resize(size,Image.ANTIALIAS)  
   img.save('ddd.jpg')  
   img = cv2.imread('ddd.jpg'#读取图像  
   #因为是单张图片的时间太短,每一张图片插入20帧  
   for j in range(0,20):  
       videoWrite.write(img)  
videoWrite.release()

但是如果要将图片做一些简单的动画效果,例如做一个画面逐渐缩小的动画,那就要借助EV剪辑,调整图片的大小,加上白背景,然后导出视频。

用 Python 和 EV 剪辑短视频教程用 Python 和 EV 剪辑短视频教程

注意导出的时候要设置帧率,如果时间过长,可以设置设置帧率低一点,然后用python程序把播放速度提升,帧率也会相应提高。

import cv2  
vdop = "4.mp4"#输入视频路径  cap = cv2.VideoCapture(vdop)  
fps = cap.get(cv2.CAP_PROP_FPS) #获取输入视频的帧率
size = (int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)),  
       int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT)))#获取输入视频的大小  
fourcc = cv2.VideoWriter_fourcc('I''4''2''0')  #These are the FOURCCs to compressed formats  
out_path = "8.mp4" #输出2倍速的avi格式的视频路径  
output_viedo = cv2.VideoWriter()  
fps = (29.5/26.8)*fps #2倍速处理  #isColor:如果该位值为Ture,解码器会进行颜色框架的解码,否则会使用灰度进行颜色架构  
output_viedo.open(out_path , fourcc, fps, size, isColor=True)  
rval = True  
while rval:  
   rval, img = cap.read()#逐帧读取原视频  
   output_viedo.write(img)#写入视频帧  
output_viedo.release()  
cap.release()

用opencv处理过的视频会失去音频。我们也可以使用ffmpeg来调速,可以保留声音,特别适合微调。要使用FFmpeg,安装完之后,设置环境变量,就能在python调用FFmpeg。

import os  
os.system('ffmpeg -i 4.mp4 -vf  "setpts=2*PTS" 8.mp4')  #图像两倍慢速  

二、将视频添加音频作为背景音乐

import subprocess,os  
mp4_f = './2.avi'  
mp3_f = './背景音.mp3'  
n_mp4_n = 'new' + mp4_f.split('/')[-1]
n_mp4_f = mp4_f.replace(mp4_f.split('/')[-1],n_mp4_n)  
com = f'D:\\ffmpeg\\bin\\ffmpeg.exe -i "{mp3_f}" -i "{mp4_f}" ' \ f' -acodec copy -vcodec copy "{n_mp4_f}"'  
print(com)  
os.system(com)

三、合并视频

1.剪切视频

import os  
import subprocess,cv2  
com = f'ffmpeg -i 5.mp4 -c copy -t 00:00:20.0 output.mp4'  # 截取前20秒  -ss 00:00:00.0   起始位置  
os.system(com)

2.要将不同的视频合并,首先要确保帧率和画布大小一样,这样才能确保合并起来不出错。下面代码是调整画布。将形状不同的视频画面,要按照原视频的比例,调整到一个框里面去。

import subprocess,os  
import cv2  
#获取样本的画布大小  
video_path = "2\\1.mp4"  
cap = cv2.VideoCapture(video_path)  
frame_width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))# 获取视频高度  
frame_height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))# 获取视频宽度  
fps = cap.get(cv2.CAP_PROP_FPS) #视频平均帧率  
h0=frame_height  
w0=frame_width  
file_list = os.listdir('3\\')   #获取文件夹里的所有文件列表  for i in file_list:  
 #获取当前视频的  
 video_path = '3\\'+i  
 cap = cv2.VideoCapture(video_path)  
 frame_width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
 # 获取视频高度、宽度  
 frame_height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))  
 h=frame_height  
 w=frame_width  
 if h/w>h0/w0:    
   strn=f'ffmpeg -i %s -vf "scale=(%s*%s/%s):%s,pad=%s:%s:(%s-(%s*%s/%s))/2:0:black" %s'%  (video_path,w,h0,h,h0,        w0,h0,w0,w,h0,h,i)  
 else:              
    strn=f'ffmpeg -i  %s -vf "scale=%s:%s*%s/%s,pad=%s:%s:0:((%s-(%s*%s/%s))/2):black"  %s'%    (video_path,w0,w0,h,w,       w0,h0,          h0,w0,h,w,i)  
                             #本图缩放后=宽:高,位置=总宽:总高:水平方向放置的位置:垂直方向放置的位置  
 os.system(strn)

3.将视频合并

将视频先转化成ts格式,然后再合并,成功率更高。

import os  
lista='kaishiwizhi'  
#先获取这些MP4文件,转换成ts格式  for each in os.listdir():  
   if each[-3:] in ['mp4','avi'] :  
       os.system('ffmpeg.exe -i %s -c copy -vbsf h264_mp4toannexb %s.ts' % (each, each[:-4]))  
       listalista=lista +('|%s.ts'%(each[:-4]))  
listalista=lista.replace('kaishiwizhi|','')  
import subprocess,cv2  
#subprocess.call(cmd, shell=True)  
com = f'ffmpeg -i "concat:%s" -c copy 333333.avi'%lista  
#com = f'mencoder -forceidx -of lavf -oac copy -ovc copy -o output.avinew 2.avi new 2.avi'  print(com)  
os.system(com)  

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/221819.html<

(0)
运维的头像运维
上一篇2025-04-15 05:16
下一篇 2025-04-15 05:17

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注