Python Video lesen und speichern
Der Inhalt stammt von blog + blog ~
Videos lesen
Der Vorteil der Verwendung der cv2-Bibliothek besteht darin, dass die Rückgabe ohne Konvertierung arrary erfolgt, diese Methode jedoch von Anfang bis Ende gelesen wird
Unter Verwendung der cv2-Bibliothek zum Lesen des Videos wird der Code wie folgt implementiert:
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()
Video lesen und speichern
- Videos lesen
- Verarbeiten Sie jeden Frame
- Videos speichern
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() ist eine Tastaturbindungsfunktion. Sein Zeitmaß ist Millisekunden ms. Die Funktion wartet n Millisekunden innerhalb von (n), um zu sehen, ob eine Tastatureingabe erfolgt. Gibt es eine Tastatureingabe, geben Sie den ASCII-Wert der Taste zurück. Wenn es keine Tastatureingabe gibt, gibt es -1 zurück.Im Allgemeinen auf 0 gesetzt, wird es drahtlos auf Tastatureingaben warten.
cv2.VideoWriter_fourcc()-Funktion
fourcc bedeutet Vier-Zeichen-Codes (Four-Character Codes), der Code besteht aus vier Zeichen, die folgenden sind einige häufig verwendete Parameter des VideoWriter_fourcc-Objekts:
Hinweis: Die Zeichenreihenfolge kann nicht gemischt werden
- cv2.VideoWriter_fourcc('I','4','2','0'), der Parameter ist YUV-Kodierungstyp, das Dateinamensuffix ist .avi
- cv2.VideoWriter_fourcc('P','I','M','I'), der Parameter ist MPEG-1-Kodierungstyp, das Dateinamensuffix ist .avi
- cv2.VideoWriter_fourcc('X','V','I','D'), der Parameter ist MPEG-4-Kodierungstyp, das Dateinamensuffix ist .avi
- cv2.VideoWriter_fourcc('T','H','E','O'), der Parameter ist Ogg Vorbis, die Dateinamenserweiterung ist .ogv
- cv2.VideoWriter_fourcc('F','L','V',1), der Parameter ist Flash-Video, das Dateinamensuffix ist .flv
cv2.flip()-Funktion
Grammatik:
cv2.flip(src, flipCode[, dst]) #src为要操作的图像
So verwenden Sie flipCode:
flipCode=-1 #水平垂直翻转
flipCode= 0 #垂直翻转
flipCode= 1 #水平翻转
Anwendung:
cv2.imshow('img1',cv2.flip(img,-1))#水平垂直翻转
cv2.imshow('img2',cv2.flip(img,0))#垂直翻转
cv2.imshow('img3',cv2.flip(img,1))#水平翻转
Erstmals geschrieben am 23. August 2021.