【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实现图文成片功能

相关推荐
IVEN_4 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang5 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮5 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling5 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮9 小时前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽9 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健1 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞1 天前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽1 天前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers