【Python音视频技术】用moviepy实现图文成片功能

今天上班的时候看到有人群里问 图文成片怎么实现。 临时给我提供一点写作的灵感,趁着下班写一篇。这里用到 python的moviepy库, 之前文章介绍过。

大体思路:假定有4张图片,每张图片将在视频中展示2秒钟,并且图片会按照顺序循环播放,直到音频结束。

python 复制代码
from moviepy.efrom moviepy.editor import ImageClip, AudioFileClip, concatenate_videoclips, CompositeVideoClip
from moviepy.audio.fx.all import audio_loop
from PIL import Image
import os


def resize_images(image_files, desired_size):
    resized_images = []
    for image_file in image_files:
        # 打开一张图片文件
        with Image.open(image_file) as img:
            # 调整图片大小到目标尺寸
            img = img.resize(desired_size, Image.ANTIALIAS)
            # 将调整后的图片保存到临时文件
            temp_file = f"temp_{os.path.basename(image_file)}"
            img.save(temp_file)
            resized_images.append(temp_file)
    return resized_images


def create_video_from_images(image_files, audio_file, output_file, fps=24, desired_size=(1280, 720)):
    # 将图片调整到目标尺寸
    resized_images = resize_images(image_files, desired_size)

    # 加载音频文件
    audio = AudioFileClip(audio_file)

    # 设置图片展示时长为2秒
    image_duration = 2

    # 创建单独的图片剪辑并设置展示时长
    clips = [ImageClip(img).set_duration(image_duration).set_fps(fps) for img in resized_images]

    # 将所有图片剪辑拼接成循环播放的一个视频剪辑
    video_clip = concatenate_videoclips(clips, method="compose").loop(duration=audio.duration)

    # 给视频剪辑设置音频
    final_video = video_clip.set_audio(audio)

    # 将结果写入输出文件
    final_video.write_videofile(output_file, codec="libx264", audio_codec="aac", fps=fps)

    # 清理临时文件
    for temp_file in resized_images:
        os.remove(temp_file)


# demo:
image_files = ['image1.jpg', 'image2.jpg', 'image3.jpg', 'image4.jpg']  # 图片文件列表
audio_file = 'background_music.mp3'  # 音频文件
output_file = 'output_video.mp4'  # 输出视频文件

create_video_from_images(image_files, audio_file, output_file)ditor import ImageClip, AudioFileClip, concatenate_videoclips, CompositeVideoClip
from moviepy.audio.fx.all import audio_loop
from PIL import Image
import os


def resize_images(image_files, desired_size):
    resized_images = []
    for image_file in image_files:
        # 打开一张图片文件
        with Image.open(image_file) as img:
            # 调整图片大小到目标尺寸
            img = img.resize(desired_size, Image.ANTIALIAS)
            # 将调整后的图片保存到临时文件
            temp_file = f"temp_{os.path.basename(image_file)}"
            img.save(temp_file)
            resized_images.append(temp_file)
    return resized_images


def create_video_from_images(image_files, audio_file, output_file, fps=24, desired_size=(1280, 720)):
    # 将图片调整到目标尺寸
    resized_images = resize_images(image_files, desired_size)

    # 加载音频文件
    audio = AudioFileClip(audio_file)

    # 设置图片展示时长为2秒
    image_duration = 2

    # 创建单独的图片剪辑并设置展示时长
    clips = [ImageClip(img).set_duration(image_duration).set_fps(fps) for img in resized_images]

    # 将所有图片剪辑拼接成循环播放的一个视频剪辑
    video_clip = concatenate_videoclips(clips, method="compose").loop(duration=audio.duration)

    # 给视频剪辑设置音频
    final_video = video_clip.set_audio(audio)

    # 将结果写入输出文件
    final_video.write_videofile(output_file, codec="libx264", audio_codec="aac", fps=fps)

    # 清理临时文件
    for temp_file in resized_images:
        os.remove(temp_file)


# demo:
image_files = ['image1.jpg', 'image2.jpg', 'image3.jpg', 'image4.jpg']  # 图片文件列表
audio_file = 'background_music.mp3'  # 音频文件
output_file = 'output_video.mp4'  # 输出视频文件

create_video_from_images(image_files, audio_file, output_file)

这里的图片素材采用腾讯智影生成, 音频采用suno生成。最后的效果

相关文章:

【Python音视频技术】玩AI视频创作引发写Python音视频技术系列文章1---视频添加字幕

【Python音视频技术】Python音视频技术系列文章2---视频提取音频转换文字

【Python音视频技术】Python音视频技术系列文章3---音频转换文字技术方案

原文链接:【Python音视频技术】用moviepy实现图文成片功能

相关推荐
我要学习别拦我~11 分钟前
kaggle分析项目:steam付费游戏数据分析
python·游戏·数据分析
大模型真好玩17 分钟前
深入浅出LangChain AI Agent智能体开发教程(四)—LangChain记忆存储与多轮对话机器人搭建
前端·人工智能·python
love530love19 分钟前
命令行创建 UV 环境及本地化实战演示—— 基于《Python 多版本与开发环境治理架构设计》的最佳实践
开发语言·人工智能·windows·python·conda·uv
陪我一起学编程41 分钟前
MySQL创建普通用户并为其分配相关权限的操作步骤
开发语言·数据库·后端·mysql·oracle
都叫我大帅哥42 分钟前
深度学习的"Hello World":多层感知机全解指南
python·深度学习
麦子邪43 分钟前
C语言中奇技淫巧04-仅对指定函数启用编译优化
linux·c语言·开发语言
都叫我大帅哥1 小时前
LangChain分层记忆解决方案:完整案例
python·langchain
小王子10241 小时前
Django实时通信实战:WebSocket与ASGI全解析(下)
python·websocket·django
破刺不会编程1 小时前
linux线程概念和控制
linux·运维·服务器·开发语言·c++
alex1001 小时前
AI Agent开发学习系列 - langchain之LCEL(5):如何创建一个Agent?
人工智能·python·语言模型·langchain·prompt·向量数据库·ai agent