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('裁剪完成...')
相关文章
|
1月前
|
计算机视觉 Python
Python实用记录(一):如何将不同类型视频按关键帧提取并保存图片,实现图片裁剪功能
这篇文章介绍了如何使用Python和OpenCV库从不同格式的视频文件中按关键帧提取图片,并展示了图片裁剪的方法。
66 0
|
1月前
|
机器学习/深度学习 编解码 Python
python将照片集变成视频
`shigen`是一位坚持更新文章的博客作者,记录成长历程,分享认知见解,留住生活感动。他利用Python库`Pillow`和`MoviePy`开发了一个工具,能够批量处理照片并生成高质量视频。该工具支持多种分辨率、自定义播放时间和照片方向,并能自动调整照片比例以实现居中对齐。通过简单的代码实现了照片视频化的需求,适合强迫症患者使用。**与shigen一起,每天不一样!**个人IP:shigen。
43 9
python将照片集变成视频
|
5月前
|
Python
Python使用ffmpeg下载m3u8拼接为视频
Python使用ffmpeg下载m3u8拼接为视频
|
28天前
|
数据安全/隐私保护 流计算 开发者
python知识点100篇系列(18)-解析m3u8文件的下载视频
【10月更文挑战第6天】m3u8是苹果公司推出的一种视频播放标准,采用UTF-8编码,主要用于记录视频的网络地址。HLS(Http Live Streaming)是苹果公司提出的一种基于HTTP的流媒体传输协议,通过m3u8索引文件按序访问ts文件,实现音视频播放。本文介绍了如何通过浏览器找到m3u8文件,解析m3u8文件获取ts文件地址,下载ts文件并解密(如有必要),最后使用ffmpeg合并ts文件为mp4文件。
|
2月前
|
编解码 Python
Python如何给视频添加音频和字幕
Python如何给视频添加音频和字幕
|
5月前
|
存储 Python
python实现图片与视频转换:将视频保存为图片,将批量图片保存为视频
python实现图片与视频转换:将视频保存为图片,将批量图片保存为视频
|
2月前
|
编解码 Python Windows
python有没有包 可以检测 这个视频是否可以播放
python有没有包 可以检测 这个视频是否可以播放
|
2月前
|
前端开发 JavaScript 关系型数据库
基于Python+Vue开发的反诈视频宣传管理系统
基于Python+Vue开发的反诈视频宣传管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Python编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Python的反诈宣传管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
33 4
|
3月前
|
自然语言处理 数据挖掘 开发者
Python腾讯视频16978条弹幕,发现弹幕比剧还精彩
Python腾讯视频16978条弹幕,发现弹幕比剧还精彩
54 4
Python腾讯视频16978条弹幕,发现弹幕比剧还精彩
|
3月前
|
存储 数据可视化 Python
使用python moviepy提取视频中的音频,同时对音频数据进行数据可视化分析
使用python moviepy提取视频中的音频,同时对音频数据进行数据可视化分析
133 0