Opération vidéo Python - Python réalise la lecture et l'enregistrement de la vidéo

python lit et enregistre la vidéo

Le contenu provient de blog + blog ~

lire la vidéo

L'avantage d'utiliser la bibliothèque cv2 est que le retour est arrary sans conversion, mais cette méthode est lue du début à la fin

En utilisant la bibliothèque cv2 pour lire la vidéo, le code est implémenté comme suit :

import cv2

cap = cv2.VideoCapture('C:\\Users\\xxx\\Desktop\\sweet.mp4')

while(cap.isOpened()):
    # ret返回布尔值
    ret, frame = cap.read()
    # 展示读取到的视频矩阵
    cv2.imshow('image', frame)
    # 键盘等待
    k = cv2.waitKey(20)
    # q键退出
    if k & 0xff == ord('q'):
        break

# 释放资源
cap.release()
# 关闭窗口
cv2.destroyAllWindows()

lire et enregistrer la vidéo

  1. lire la vidéo
  2. Traiter chaque image
  3. enregistrer la vidéo
import cv2

# VideoCapture方法是cv2库提供的读取视频方法
cap = cv2.VideoCapture('C:\\Users\\xxx\\Desktop\\sweet.mp4')
# 设置需要保存视频的格式“xvid”
# 该参数是MPEG-4编码类型,文件名后缀为.avi
fourcc = cv2.VideoWriter_fourcc(*'XVID')
# 设置视频帧频
fps = cap.get(cv2.CAP_PROP_FPS)
# 设置视频大小
size = (int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)),int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT)))
# VideoWriter方法是cv2库提供的保存视频方法
# 按照设置的格式来out输出
out = cv2.VideoWriter('C:\\Users\\xxx\\Desktop\\out.avi',fourcc ,fps, size)

# 确定视频打开并循环读取
while(cap.isOpened()):
    # 逐帧读取,ret返回布尔值
    # 参数ret为True 或者False,代表有没有读取到图片
    # frame表示截取到一帧的图片
    ret, frame = cap.read()
    if ret == True:
        # 垂直翻转矩阵
        frame = cv2.flip(frame,0)

        out.write(frame)

        cv2.imshow('frame',frame)
        if cv2.waitKey(1) & 0xFF == ord('q'):
            break
    else:
        break

# 释放资源
cap.release()
out.release()
# 关闭窗口
cv2.destroyAllWindows()

cv2.waitKey() est une fonction de liaison au clavier. Sa mesure temporelle est la milliseconde ms. La fonction attendra n millisecondes à l'intérieur de (n) pour voir s'il y a une entrée au clavier. S'il y a une entrée au clavier, renvoie la valeur ASCII de la touche. S'il n'y a pas d'entrée au clavier, il renvoie -1. Généralement réglé sur 0, il attendra sans fil l'entrée au clavier.

Fonction cv2.VideoWriter_fourcc()

fourcc signifie codes à quatre caractères (codes à quatre caractères), le code se compose de quatre caractères, voici quelques paramètres couramment utilisés de l'objet VideoWriter_fourcc :

Remarque : l'ordre des caractères ne peut pas être mélangé

  • cv2.VideoWriter_fourcc('I','4','2','0'), le paramètre est le type d'encodage YUV, le suffixe du nom de fichier est .avi
  • cv2.VideoWriter_fourcc('P','I','M','I'), le paramètre est le type d'encodage MPEG-1, le suffixe du nom de fichier est .avi
  • cv2.VideoWriter_fourcc('X','V','I','D'), le paramètre est le type d'encodage MPEG-4, le suffixe du nom de fichier est .avi
  • cv2.VideoWriter_fourcc('T','H','E','O'), le paramètre est Ogg Vorbis, le suffixe du nom de fichier est ​​.ogv
  • cv2.VideoWriter_fourcc('F','L','V',1), le paramètre est la vidéo Flash, le suffixe du nom de fichier est .flv

fonction cv2.flip()

grammaire:

cv2.flip(src, flipCode[, dst]) #src为要操作的图像

Comment utiliser flipCode :

flipCode=-1        #水平垂直翻转
flipCode= 0        #垂直翻转
flipCode= 1        #水平翻转

application:

cv2.imshow('img1',cv2.flip(img,-1))#水平垂直翻转
cv2.imshow('img2',cv2.flip(img,0))#垂直翻转
cv2.imshow('img3',cv2.flip(img,1))#水平翻转

insérez la description de l'image ici

Première rédaction le 23 août 2021.

Je suppose que tu aimes

Origine blog.csdn.net/weixin_52777510/article/details/119872183
conseillé
Classement