python-(opencv)视频转glf

文章目录

  • 前言
    • python-(opencv)视频转glf
      • [1. 下载 opencv-python](#1. 下载 opencv-python)
      • [2. cv2(OpenCV)和imageio的区别](#2. cv2(OpenCV)和imageio的区别)
      • [3. demo源码](#3. demo源码)

前言

如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^ _ ^。

而且听说点赞的人每天的运气都不会太差,实在白嫖的话,那欢迎常来啊!!!


python-(opencv)视频转glf

cv2(OpenCV)和imageio 都可以用来将视频转出glf的的python库。

我这里使用的是cv2(OpenCV)python库来做视频转glf demo。

1. 下载 opencv-python

pip install opencv-python

2. cv2(OpenCV)和imageio的区别

功能和应用场景:

OpenCV (cv2):OpenCV 是一个功能强大的计算机视觉库,支持广泛的图像处理、计算机视觉和机器学习任务,如图像处理、视频处理、对象检测与跟踪、人脸识别等。它提供了丰富的算法和函数,适用于复杂的计算机视觉项目。

imageio:imageio 是一个用于读写多种图像和视频格式的库。它的主要功能是方便地读取和写入图像和视频文件,支持多种格式,并且可以直接处理GIF动画等。imageio 的设计更加简洁,专注于图像和视频的I/O操作。
易用性和适用范围:

OpenCV 在处理复杂的计算机视觉任务时更为强大和灵活,提供了丰富的图像处理算法和功能。

imageio 更适合于简单的图像和视频读写操作,特别是对于处理少量数据或需要快速实现的任务而言更为便捷。
依赖和兼容性:

OpenCV 需要依赖于底层的计算机视觉和数值计算库,如 numpy 等,而且需要正确配置编译环境,适应性较强。

imageio 设计简单,依赖较少,适用于快速安装和使用的场景。
社区和支持:

OpenCV 是一个广为人知且使用广泛的开源项目,有一个活跃的社区支持和大量的文档资源。

imageio 也有不少用户和社区支持,但相对于OpenCV来说,其社区和文档资源可能较少。


因此选择使用哪个库取决于你的具体需求和项目复杂性。如果需要进行复杂的计算机视觉任务或者需要丰富的图像处理功能,推荐使用 OpenCV (cv2)。如果只需进行简单的图像和视频读写操作,并希望快速上手,那么 imageio 是一个不错的选择。

3. demo源码

python 复制代码
import cv2
from PIL import Image
import time

# 视频文件路径
video_path = 'D:/嗨格式录屏文件/test.mp4'

# 打开视频文件
cap = cv2.VideoCapture(video_path)

# 获取视频帧率和总帧数
fps = int(cap.get(cv2.CAP_PROP_FPS))
frame_count = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))
print(f'视频帧率:{fps}')
print(f'总帧数:{frame_count}')

# 图片尺寸(这里使用视频的默认尺寸)
width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))


# 逐帧读取视频并保存为图片
def read_frames():
    while True:
        ret, frame = cap.read()
        if not ret:
            break
        frame_rgb = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)  # 将 OpenCV 的 BGR 格式转换为 RGB 格式
        yield Image.fromarray(frame_rgb)  # 将 NumPy 数组转换为 PIL 图像对象


print("保存为 GIF 动画")

# 记录开始时间
start_time = time.time()

# 保存为 GIF 动画
images = list(read_frames())

images[0].save('D:/嗨格式录屏文件/test.gif',
               save_all=True,
               append_images=images[1:],
               duration=int(1000 / fps),  # 每帧间隔时间(毫秒)
               loop=0)                   # 循环次数(0 表示无限循环)

# 计算耗时
elapsed_time = time.time() - start_time
print(f"视频转换为 GIF 图片成功,耗时: {elapsed_time:.2f} 秒。")

# 释放视频文件资源
cap.release()

效果:

可以看到耗时6分钟,时间还是比较久的,这种场景下,可以采取优化
【调整帧采样率】【使用其他视频处理库】(虑使用其他专门用于视频处理和转换的库,比如 moviepy 或 imageio。它们可能针对性能和效率进行了优化,可以比原生 OpenCV 更快速地进行帧的读取和处理。)、调**【整保存参数】(整保存 GIF 图像时的参数,例如调整每帧的间隔时间、循环次数等。有时候减少帧率或减少循环次数可以减少处理时间),【使用多线程或异步处理】(在读取帧和保存图像时,可以考虑使用多线程或异步处理。这样可以并行处理帧的读取和图像的保存,提高整体处理速度),【降低图像尺寸和质量】**(如果目标是减少文件大小或简化处理过程,可以在保存 GIF 图像时降低图像的尺寸和质量。这会减少每帧的处理时间和最终 GIF 文件的大小)。

下面是通过调整调整帧采样率的demo:

python 复制代码
import cv2
from PIL import Image
import time

# 视频文件路径
video_path = 'D:/嗨格式录屏文件/test.mp4'

# 打开视频文件
cap = cv2.VideoCapture(video_path)

# 获取视频帧率和总帧数
fps = int(cap.get(cv2.CAP_PROP_FPS))
frame_count = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))
print(f'视频帧率:{fps}')
print(f'总帧数:{frame_count}')

# 图片尺寸(这里使用视频的默认尺寸)
width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))


# 逐帧读取视频并保存为图片(增加帧采样率)
def read_frames(sampling_rate=2):
    frame_number = 0
    while True:
        ret, frame = cap.read()
        if not ret:
            break
        if frame_number % sampling_rate == 0:
            frame_rgb = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)
            yield Image.fromarray(frame_rgb)
        frame_number += 1


print("保存为 GIF 动画")

# 记录开始时间
start_time = time.time()


# 调整帧采样率为每隔2帧保存一次图像
images = list(read_frames(sampling_rate=2))
images[0].save('D:/嗨格式录屏文件/test.gif',
               save_all=True,
               append_images=images[1:],
               duration=int(1000 / fps),  # 每帧间隔时间(毫秒)
               loop=0)                   # 循环次数(0 表示无限循环)

# 计算耗时
elapsed_time = time.time() - start_time
print(f"视频转换为 GIF 图片成功,耗时: {elapsed_time:.2f} 秒。")

# 释放视频文件资源
cap.release()

效果:

明显生成时间减少很多。

相关推荐
肥猪猪爸16 分钟前
使用卡尔曼滤波器估计pybullet中的机器人位置
数据结构·人工智能·python·算法·机器人·卡尔曼滤波·pybullet
大白要努力!17 分钟前
Android opencv使用Core.hconcat 进行图像拼接
android·opencv
LZXCyrus1 小时前
【杂记】vLLM如何指定GPU单卡/多卡离线推理
人工智能·经验分享·python·深度学习·语言模型·llm·vllm
Enougme1 小时前
Appium常用的使用方法(一)
python·appium
懷淰メ1 小时前
PyQt飞机大战游戏(附下载地址)
开发语言·python·qt·游戏·pyqt·游戏开发·pyqt5
EasyCVR1 小时前
私有化部署视频平台EasyCVR宇视设备视频平台如何构建视频联网平台及升级视频转码业务?
大数据·网络·音视频·h.265
hummhumm1 小时前
第 22 章 - Go语言 测试与基准测试
java·大数据·开发语言·前端·python·golang·log4j
天空中的野鸟1 小时前
Android音频采集
android·音视频
hummhumm1 小时前
第 28 章 - Go语言 Web 开发入门
java·开发语言·前端·python·sql·golang·前端框架
只怕自己不够好1 小时前
《OpenCV 图像基础操作全解析:从读取到像素处理与 ROI 应用》
人工智能·opencv·计算机视觉