您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:Python将视频转换为图片介绍

51自学网 2022-02-21 10:36:45
  python
这篇教程Python将视频转换为图片介绍写得很实用,希望能帮到您。

前言

代码让人头秃,可是我喜欢上了代码的逻辑感和代码解决问题的力量。
(我要对这个专题的图片进行修改,缩小看和我导头像有点像QAQ)

代码展示

此段代码能够实现多个文件夹中多个视频片段的转换,代码的具体含义可以参考注释。
具体操作为将此段代码复制粘贴到创建好的main.py文件,配置好第63行的源文件路径,然后运行。

# 将四个文件夹中的多个视频文件转换为图片import cv2import osnumber_in_dir = []  # 可以去掉def video2image(video_path, image_save_dir):    # 1. 将图片的存储路径加上源文件的文件夹名,如'Coffee_room_01'等。    if os.path.exists(video_path):  # 判断源路径是否正确        print(video_path + '/t ok')        if video_path.split('//')[-2] != 'Videos':  # 这个根据我文件路径自行添加的            image_save_dir += video_path.split('//')[-2] + '//'        else:            image_save_dir += video_path.split('//')[-3] + '//'        number_in_dir.append(len(os.listdir(video_path)))  # 可以去掉    else:        print(video_path + ' /033[0;37;41merror/033[0m')        return    # 2. 依次读取源文件里的文件,如果后缀名是‘avi'或 'MP3',则创建一个关于文件名的子文件夹    files_in_video_path_list = os.listdir(video_path)    print(len(files_in_video_path_list))  # 获取当前文件夹下文件个数,用来判断是否有其他类型的文件    file_count = 0  # 用于统计个数,验证是否全为视频文件,会与len(files_in_video_path_list)进行比较    for file_in_video_path in files_in_video_path_list:        file_name = os.path.basename(file_in_video_path)        if file_name.split('.')[-1] == 'avi' or file_name.split('.')[-1] == 'mp3':            file_count += 1  # 视频文件数+1            every_video_save_dir = file_name.split('.')[0] + '//'            if not os.path.exists(image_save_dir + every_video_save_dir):  # 创建属于相应文件夹的存储路径                os.makedirs(image_save_dir + every_video_save_dir)        else:            print(' /033[0;37;41merror/033[0m')            break        # 3. 打印正在处理文件的序号和他的文件名,并开始转换        print(str(file_count) + ':' + file_name)        cap = cv2.VideoCapture(video_path + file_name)        flag = cap.isOpened()        if not flag:            print("open" + video_path + file_name + "error!")        frame_count = 0  # 给每一帧标号        while True:            frame_count += 1            flag, frame = cap.read()            if not flag:  # 如果已经读取到最后一帧则退出                break            if os.path.exists(image_save_dir + every_video_save_dir + str(frame_count) + '.jpg'):  # 在源视频不变的情况下,如果已经创建,则跳过                break            cv2.imwrite(image_save_dir + every_video_save_dir + str(frame_count) + '.jpg', frame)        cap.release()        print(file_name + ' save to ' + image_save_dir + every_video_save_dir + 'finished ')  # 表示一个视频片段已经转换完成    if file_count != len(files_in_video_path_list):        print(' /033[0;37;41Maybe loss something/033[0m')if __name__ == '__main__':    # 需要转换的文件路径列表(自定义修改)    video_path_list = ['E://Datasets_FallDetection//2 LE2I/Coffee_room_01//Coffee_room_01//Videos//',                       'E://Datasets_FallDetection//2 LE2I/Home_01//Home_01/Videos//',                       'E://Datasets_FallDetection//2 LE2I/Lecture_room//Lecture room//',                       'E://Datasets_FallDetection//2 LE2I//Office//Office//']    # 预期存储在的主文件夹,即'result'文件夹    image_save_dir = './/result//'    # 进行转换    for video_path in video_path_list:        video2image(video_path, image_save_dir)

结果展示

将创建’result’主文件夹和副文件夹

在这里插入图片描述

每个副文件夹下都将生成与视频名相对应的子文件夹,并按视频帧数顺序转换为jpg图片。

在这里插入图片描述

终端上将提示正在处理的文件路径,正在对哪个视频进行转换和转换完成提示。

在这里插入图片描述

总结

到此这篇关于Python将视频转换为图片介绍的文章就介绍到这了,更多相关Python视频转换为图片内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


python selenium禁止加载某些请求的实现
如何利用python实现windows的批处理及文件夹操作
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。