单双目视频转图片

视频转图片

视频转图片

输入文件夹路径,里面时mp4视频

输出的是每隔1秒提取到的视频帧

interval是每隔多少秒保存一张图片

python 复制代码
import cv2
import os

img_count = 1


def save_frames(video_path, output_folder, interval):
    # 创建保存图片的文件夹
    if not os.path.exists(output_folder):
        os.makedirs(output_folder)

    # 打开视频文件
    cap = cv2.VideoCapture(video_path)
    frame_count = 0
    global img_count

    while cap.isOpened():
        ret, frame = cap.read()

        # 判断是否成功读取帧
        if not ret:
            break

        frame_count += 1

        # 每两秒保存一帧图片
        if frame_count % (interval * cap.get(cv2.CAP_PROP_FPS)) == 0:
            img_name = f"20240524_{img_count}.jpg"
            img_path = os.path.join(output_folder, img_name)
            cv2.imwrite(img_path, frame)
            print('file saved:', img_path)
            print(img_count)
            img_count += 1

    cap.release()


# 设置输入文件夹和输出文件夹路径
input_folder = "path"
output_folder = "path"

# 遍历文件夹中的所有.dav视频文件
for filename in os.listdir(input_folder):
    if filename.endswith(".dav"):
        video_path = os.path.join(input_folder, filename)
        save_frames(video_path, output_folder, 1)

双目视频,提取单目

输入文件夹路径,里面时mp4视频

输出的是每隔1秒提取到的视频帧

img_name是视频帧名字的命名格式,自动编号

python 复制代码
import cv2
import os

img_count = 1

def extract_left_eye_frame(video_path, output_folder):

    global img_count
    # 打开视频文件
    cap = cv2.VideoCapture(video_path)
    frame_rate = cap.get(cv2.CAP_PROP_FPS)
    frame_width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
    half_width = frame_width // 2

    # img_count = 1
    last_saved_time = 0.0
    while cap.isOpened():
        ret, frame = cap.read()
        if not ret:
            break

        current_time = cap.get(cv2.CAP_PROP_POS_MSEC) / 1000.0  # 当前帧的时间戳(秒)

        # 如果超过一秒钟才保存下一帧
        if current_time - last_saved_time >= 1.0: # 1.0
            # 提取左目图片
            left_eye_frame = frame[:, :half_width]
             # 提取右目图片
            # right_eye_frame = frame[:,half_width:]

            # 保存图片
            img_name = f"20240422xiaomi_{img_count}.jpg"
            img_path = os.path.join(output_folder, img_name)
            cv2.imwrite(img_path, left_eye_frame)
            print(f"Saved: {img_path}")
            img_count += 1
            last_saved_time = current_time

    cap.release()


# 设置输入文件夹和输出文件夹路径
input_folder = "path"
output_folder = "path"

# 确保输出文件夹存在
if not os.path.exists(output_folder):
    os.makedirs(output_folder)

# 遍历文件夹中的所有.mp4视频文件
for filename in os.listdir(input_folder):
    if filename.endswith(".mp4"):
        print(f"Processing: {filename}")
        video_path = os.path.join(input_folder, filename)
        extract_left_eye_frame(video_path, output_folder)
相关推荐
进击的六角龙1 分钟前
深入浅出:使用Python调用API实现智能天气预报
开发语言·python
檀越剑指大厂1 分钟前
【Python系列】浅析 Python 中的字典更新与应用场景
开发语言·python
湫ccc9 分钟前
Python简介以及解释器安装(保姆级教学)
开发语言·python
孤独且没人爱的纸鹤12 分钟前
【深度学习】:从人工神经网络的基础原理到循环神经网络的先进技术,跨越智能算法的关键发展阶段及其未来趋势,探索技术进步与应用挑战
人工智能·python·深度学习·机器学习·ai
程序伍六七13 分钟前
day16
开发语言·c++
羊小猪~~16 分钟前
tensorflow案例7--数据增强与测试集, 训练集, 验证集的构建
人工智能·python·深度学习·机器学习·cnn·tensorflow·neo4j
wkj00117 分钟前
php操作redis
开发语言·redis·php
lzhlizihang18 分钟前
python如何使用spark操作hive
hive·python·spark
q0_0p19 分钟前
牛客小白月赛105 (Python题解) A~E
python·牛客
极客代码22 分钟前
【Python TensorFlow】进阶指南(续篇三)
开发语言·人工智能·python·深度学习·tensorflow