python实现 mp4转gif文件

python实现 mp4转gif文件

安装库:

bash 复制代码
pip install opencv-python imageio

实现python代码如下:

bash 复制代码
import cv2
import imageio
import numpy as np
import argparse
import os

def mp4_to_gif(mp4_path, gif_path=None, fps=None, scale=1.0, start=0, duration=None):
    """
    mp4 -> gif
    :param mp4_path: 输入视频
    :param gif_path: 输出路径,None 则同目录同名
    :param fps: 输出帧率,None 则与视频一致
    :param scale: 缩放因子,1.0 原尺寸,0.5 一半
    :param start: 起始时间(秒)
    :param duration: 截取时长(秒),None 表示到结尾
    """
    gif_path = gif_path or os.path.splitext(mp4_path)[0] + '.gif'

    cap = cv2.VideoCapture(mp4_path)
    vid_fps = cap.get(cv2.CAP_PROP_FPS)
    total_frames = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))
    w  = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
    h  = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))

    # 计算起止帧
    start_frame = int(start * vid_fps)
    if duration:
        end_frame = start_frame + int(duration * vid_fps)
    else:
        end_frame = total_frames
    end_frame = min(end_frame, total_frames)

    # 目标帧率
    out_fps = fps or vid_fps

    frames = []
    for idx in range(start_frame, end_frame):
        cap.set(cv2.CAP_PROP_POS_FRAMES, idx)
        ret, frame = cap.read()
        if not ret:
            break
        # BGR->RGB
        frame = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)
        # 缩放
        if scale != 1.0:
            frame = cv2.resize(frame, (int(w*scale), int(h*scale)),
                               interpolation=cv2.INTER_AREA)
        frames.append(frame)

    cap.release()

    if not frames:
        raise ValueError("未读取到任何帧,请检查截取区间")

    # 写 gif
    imageio.mimsave(gif_path, frames, fps=out_fps)
    print(f"gif 已保存 -> {gif_path}  共 {len(frames)} 帧  fps={out_fps}")


if __name__ == "__main__":
    parser = argparse.ArgumentParser()
    parser.add_argument("mp4", help="输入 mp4 文件")
    parser.add_argument("-o", "--output", help="输出 gif 路径")
    parser.add_argument("--fps", type=float, help="输出帧率")
    parser.add_argument("--scale", type=float, default=0.5, help="缩放因子,默认 0.5")
    parser.add_argument("--start", type=float, default=0, help="起始时间(秒)")
    parser.add_argument("--duration", type=float, help="截取时长(秒)")
    args = parser.parse_args()

    mp4_to_gif(args.mp4, args.output, args.fps, args.scale,
               args.start, args.duration)

实现指令:

bash 复制代码
python mp42gif.py demo.mp4 --scale 0.4 --fps 10 --start 5 --duration 3

实现示例效果如下:

相关推荐
aiguangyuan3 分钟前
基于BERT的中文命名实体识别实战解析
人工智能·python·nlp
喵手3 分钟前
Python爬虫实战:知识挖掘机 - 知乎问答与专栏文章的深度分页采集系统(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集知乎问答与专栏文章·采集知乎数据·采集知乎数据存储sqlite
铉铉这波能秀4 分钟前
LeetCode Hot100数据结构背景知识之元组(Tuple)Python2026新版
数据结构·python·算法·leetcode·元组·tuple
kali-Myon5 分钟前
2025春秋杯网络安全联赛冬季赛-day2
python·安全·web安全·ai·php·pwn·ctf
Re.不晚15 分钟前
JAVA进阶之路——无奖问答挑战3
java·开发语言
代码游侠16 分钟前
C语言核心概念复习——C语言基础阶段
linux·开发语言·c++·学习
㓗冽25 分钟前
60题之内难题分析
开发语言·c++·算法
dingdingfish33 分钟前
Bash学习 - 第3章:Basic Shell Features,第5节:Shell Expansions
开发语言·学习·bash
Olamyh34 分钟前
【 超越 ReAct:手搓 Plan-and-Execute (Planner) Agent】
python·ai
rainbow688934 分钟前
C++开源库dxflib解析DXF文件实战
开发语言·c++·开源