实现的思路:将准备好的图片通过opencv读取出来,并将其设置好帧数等参数后合成为无声视频。
最后通过moviepy编辑视频将背景音乐加入到视频中。
开始之前还是需要说明一下非标准库的来源,因为有些库的名称和需要导入模块的名称不一定就是一样的。
import os # python标准库,不需要安装,用于系统文件操作相关 import cv2 # python非标准库,pip install opencv-python 多媒体处理 from PIL import Image # python非标准库,pip install pillow,图像处理 import moviepy.editor as mov # python非标准库,pip install moviepy,多媒体编辑
要使用到什么模块已经叙述了,若是没有的话安装一下就可以了。接下来第一步就是将图片素材准备好来编写如何将图片转换成视频。
def image_to_video(image_path, media_path): ''' 图片合成视频函数 :param image_path: 图片路径 :param media_path: 合成视频保存路径 :return: ''' # 获取图片路径下面的所有图片名称 image_names = os.listdir(image_path) # 对提取到的图片名称进行排序 image_names.sort(key=lambda n: int(n[:-4])) # 设置写入格式 fourcc = cv2.VideoWriter_fourcc('M', 'P', '4', 'V') # 设置每秒帧数 fps = 2 # 由于图片数目较少,这里设置的帧数比较低 # 读取第一个图片获取大小尺寸,因为需要转换成视频的图片大小尺寸是一样的 image = Image.open(image_path + image_names[0]) # 初始化媒体写入对象 media_writer = cv2.VideoWriter(media_path, fourcc, fps, image.size) # 遍历图片,将每张图片加入视频当中 for image_name in image_names: im = cv2.imread(os.path.join(image_path, image_name)) media_writer.write(im) print(image_name, '合并完成!') # 释放媒体写入对象 media_writer.release() print('无声视频写入完成!')
向合成后的无声视频中添加背景音乐,背景音乐可以选择从另外一段视频中提取音频。最后将提取到的音频文件添加到该无声视频中。
def set_music(): ''' 合成视频设置背景音乐函数 :return: ''' print('开始添加背景音乐!') # 初始化视频文件对象 clip = mov.VideoFileClip('./media.mp4') # 从某个视频中提取一段背景音乐 audio = mov.AudioFileClip('./source.mp4').subclip(0, 83) # 将背景音乐写入.mp3文件 audio.write_audiofile('./background.mp3') # 向合成好的无声视频中添加背景音乐 clip = clip.set_audio(audio) # 保存视频 clip.write_videofile('./media.mp4') print('背景音乐添加完成!') # image_to_video('./images/', './media.mp4') set_music()
上述代码块已经过素材完成测试,运行没有任何报错直接copy使用即可。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理