python将视频抽帧的的多种方式

简介: python将视频抽帧的的多种方式

最近有一个需求是将视频抽取为一个个的帧图片,使用python很方便实现,而且有多种方式;

视频转换为帧的三种方式

第一种:使用open-cv

OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux、Windows、Android和Mac OS操作系统上。它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成,同时提供了Python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法;

由于open-cv不是python的内置库,所以使用之前需要先安装;

安装方式推荐有很多种,推荐使用pip;

pip 是 Python 的包安装程序。其实,pip 就是 Python 标准库(The Python Standard Library)中的一个包,只是这个包比较特殊,用它可以来管理 Python 标准库(The Python Standard Library)中其他的包。pip 是一个命令行程序。 安装 pip 后,会向系统添加一个 pip 命令,该命令可以从命令提示符运行。

使用pip安装,打开命令行输入;

pip install open-cv

等待执行安装成功;

安装完成后,导入:

import cv2

需要注意的是,安装的库名称和导入的名称不一样

1. 开始编码:
具体思路是:
使用cv2中的VideoCapture函数加载视频,然后按帧读取,使用read方法;

    vidcap = cv2.VideoCapture(video_path)
    success, image = vidcap.read()

read方法返回两个参数,一个是读取结果是否成功,一个是图片帧;
读取结果为True,则保存图片帧为图片,需要使用cv2.imwrite方法,代码如下:

  if success:
            cv2.imwrite("frame_{0:0>3}.png".format(count), image) 
            if cv2.waitKey(10) == 27:
                break
            count += 1

累加count,方便计数;

使用open-cv保存图片完成;

第二种:使用moviepy和PIL

moviepy是python中处理视频的常用库
PIL是python中处理图片的常用库;
两个库都是第三方库,使用前需要安装;

使用pip安装moviepy和PIL
分别输入安装命令,打开命令行窗口,执行:

pip install moviepy
pip install Pillow

Pillow 是 PIL 的替代版本,PIL 软件包提供了基本的图像处理功能,如:改变图像大小,旋转图像,图像格式转换,色场空间转换,图像增强,直方图处理,插值和滤波等等
pyhon3一般使用的都是pillow;

安装完成后导入:

from moviepy.editor import *
from PIL import Image
  • 使用方法:

使用moviepy中的VideoFileClip函数加载视频信息,
使用iter_frames方法获取到每一帧
使用Image函数将每一帧转换为图片

  • 具体代码如下:
from moviepy.editor import *
from PIL import Image
def v2pngs(videofile,out_path):
    """
    将视频保存为图片
    """
    video_clip = VideoFileClip(videofile)
 
    if not os.path.exists(out_path):
        os.makedirs(out_path)
 
    for idx, frame in enumerate(video_clip.iter_frames()):
        print(">>>idx: ", idx)
        if idx % 5 > 0:
            continue
        filename = out_path+'/img_' + str(int(idx/5)).zfill(3) + ".png"
        Image.fromarray(frame).save(filename)
 
    video_clip.close()
    print("Done!")

使用FFmpeg抽帧

FFmpeg是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序;

使用ffmpeg命令可以很快的抽取视频帧;
python在使用ffmpeg命令时,只需要调用内置库os;

os.system('ffmpeg - *")

使用os.system执行命令行窗口命令;具体抽帧函数,可以参考ffmpeg官网命令;


在抽取视频帧时,有时需要获取指定分辨率的图片,那就需要先裁减原视频,ffmpeg实现此功能最方便;

使用FFmpeg裁剪视频

使用ffmpeg裁剪视频时的命令如下:

ffmpeg -i video_path -vf crop=405:720:440:0 out_path

关键参数crop,输入(x,y,width,height) 左上角坐标,宽度和高度四个参数

具体代码如下:

#! _*_ coding:utf-8 _*_
import os

def cropVideo(video_path,out_path):
    '''裁剪视频'''
    os.system('ffmpeg -i %s -vf crop=405:720:440:0 %s' % (video_path,out_path))
    print('裁剪完成...')
相关文章
|
10月前
|
Web App开发 安全 数据安全/隐私保护
利用Python+Requests实现抖音无水印视频下载
利用Python+Requests实现抖音无水印视频下载
|
10月前
|
编解码 数据安全/隐私保护 Python
抖音批量发布视频工具,自动上传视频作品笔记,python发布软件
这个抖音批量发布工具包含三个主要模块:主上传程序、配置文件和视频预处理工具。主程序
|
7月前
|
数据采集 自然语言处理 数据可视化
Python爬取B站视频评论区情感分析:从数据采集到价值挖掘
B站作为年轻人聚集地,评论蕴含丰富情感与趋势。本文详解如何用Python爬取评论,结合SnowNLP与jieba进行中文情感分析,并通过可视化挖掘用户情绪、消费意愿与内容反馈,助力精准运营与决策。
1020 0
|
11月前
|
数据采集 机器学习/深度学习 编解码
从零复现Google Veo 3:从数据预处理到视频生成的完整Python代码实现指南
本文详细介绍了一个简化版 Veo 3 文本到视频生成模型的构建过程。首先进行了数据预处理,涵盖了去重、不安全内容过滤、质量合规性检查以及数据标注等环节。
745 5
从零复现Google Veo 3:从数据预处理到视频生成的完整Python代码实现指南
|
10月前
|
API 数据安全/隐私保护 Python
小红书批量发布协议, 抖音自动批量发布软件脚本,笔记作品视频自动发布工具【python】
这个工具框架包含了小红书和抖音的批量发布功能,支持图片和视频处理、定时发布等功能
|
10月前
|
Web App开发 数据安全/隐私保护 Python
快手批量发布作品工具,自动上传视频发布软件,python实现自动脚本
这个脚本实现了快手批量上传视频的功能,包含登录、上传视频、添加描述和发布等完整流程
|
10月前
|
数据安全/隐私保护 Python
快手自动上传视频脚本,图文视频批量发布工具,快手批量发布作品软件【python】
快手批量上传工具提供了完整的视频和图文上传功能,包含登录验证、文件上传、标题设置
|
10月前
|
Web App开发 数据安全/隐私保护 Python
抖音快手小红书哔哩哔哩,批量发布作品笔记视频工具,自动发布作品上传笔记视频【python】
这个工具实现了四大平台的视频批量上传功能,包含完整的异常处理和日志记录。使用时需要配置
|
10月前
|
JSON API 数据安全/隐私保护
批量上传发布视频的软件,小红书抖音快手哔哩哔哩,自动发布上传作品工具【python】
这个项目包含完整的视频批量上传功能,支持多个平台,包含视频处理、配置管理和错误处理等功能
|
计算机视觉 Python
Python实用记录(一):如何将不同类型视频按关键帧提取并保存图片,实现图片裁剪功能
这篇文章介绍了如何使用Python和OpenCV库从不同格式的视频文件中按关键帧提取图片,并展示了图片裁剪的方法。
785 0

推荐镜像

更多