【python】video2image

import struct
import json

import cv2 
import argparse
import os

parser = argparse.ArgumentParser()
parser.add_argument('--source_video_mp4', type=str, default='/home/momenta/Downloads/dvr/202107081536.mp4')
parser.add_argument('--source_video_h264', type=str, default='/home/momenta/Downloads/dvr/tmp.h264')
parser.add_argument('--output_dir', type=str, default='output')

opt = parser.parse_args()

videoCapture = cv2.VideoCapture()
videoCapture.open(opt.source_video_mp4)


class Frame:
    def __init__(self, frame_type, start_index):
        self.frame_type = frame_type
        self.data = []


class VideoInfo:
    def __init__(self):
        self.timestamps = []


def parse_frame(frame, info):
    if frame.data[0] == 0x06 and frame.data[1] == 0x5 and frame.data[2] == 0x20:
        # for b in frame.data:
        #     logger.info(hex(b), end='')
        # logger.info()
        uuid, timestamp = struct.unpack('16sQ', bytes(frame.data[3:27]))
        print(frame.data[3:27])
        info.timestamps.append(timestamp)
    
if __name__ == '__main__':
    info = VideoInfo()
    with open(opt.source_video_h264, 'rb') as reader:
        key = 0
        count = 0
        key_found = False
        frame = None
        data = reader.read()

        print(len(data))

        for i in range(0, len(data) - 1):
            b = data[i]
            if key_found:
                key_found = False
                frame_type = b & 0x1F
                frame = Frame(frame_type, i)
                frame.data.append(b)
            else:
                if frame:
                    frame.data.append(b)
                key = (key << 8) | b
                key &= 0xFFFFFFFF
                if key & 0xFFFFFF == 0x000001:
                    count += 1
                    key_found = True
                    if frame:
                        if key == 0x000000001:
                            frame.data = frame.data[:-4]
                        else:
                            frame.data = frame.data[:-3]
                        parse_frame(frame, info)
    print(info.timestamps)
    print(len(info.timestamps))
    ind = [i for i in range(len(info.timestamps))]
    to_save = dict(zip(ind, info.timestamps))

    fps = videoCapture.get(cv2.CAP_PROP_FPS)
    frames = videoCapture.get(cv2.CAP_PROP_FRAME_COUNT)
    print("fps=",fps,"frames=",frames)
    print(int(frames))
    f1 = open("{}/timestamp.txt".format(opt.output_dir),'w')
    for i in range(int(frames)):
        ret,frame = videoCapture.read()
        if ret is True:
            timestamps = videoCapture.get(cv2.CAP_PROP_POS_MSEC)
            cv2.imwrite("{}/{}.jpg".format(opt.output_dir, to_save[i]), frame)
            f1.writelines("{}".format(timestamps))
    f1.close()
    

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值