本次学习视频里人脸情况的图像记录,先复习一下视频里的人脸识别建筑兔零基础自学python记录18|实战人脸识别项目——视频检测07-CSDN博客
照例先看源代码:
import cv2
cap=cv2.VideoCapture('test1.mp4')
num = 1
while(cap.isOpened()):
ret_flag,Vshow = cap.read()
cv2.imshow("Capture_Test",Vshow)
k = cv2.waitKey(1) & 0xFF
if k == ord('s'):
cv2.imwrite("D:mycodetest/opencv/data/jm/"+str(num)+".123"+".jpg",Vshow)
num += 1
print("success to save"+str(num)+".jpg")
print("-------------------")
elif k == ord(' '):
break
cap.release()
cv2.destroyAllWindows()
我们尝试把循环命令中学过的代码解读一下(先不管具体要循环什么):
(1) ret_flag,Vshow = cap.read()这是上次学过的代码
解读:需要从视频里读出两个值ret_flag和Vshow(图像)
还有一部分代码中涉及没有见过的部分,我们也继续进行学习:
(2) cv.imshow() 将图像数据以窗口的形式展示出来
常用于图像读取、视频帧显示、图像处理结果可视化等场景。
-
"Capture_Test":要创建或使用的窗口的名称。相同名称的窗口会被视为同一个窗口。 -
Vshow:代表要显示的图像。通常是通过cv2.VideoCapture读取视频帧或者cv2.imread读取图像文件得到的。数组的形状一般为(高度, 宽度, 通道数)。补充:对于彩色图像,通道数为 3(对应 BGR 三个颜色通道);对于灰度图像,通道数为 1。
cv2.imshow("Capture_Test",Vshow)
解读:窗口名Capture_Test,要显示的图像Vshow
(3)cv.imwrite()将图像保存到文件
cv.imwrite(filename, img)
cv2.imwrite("M:/python/workspace/PythonProject/cv/"+str(num)+".123"+".jpg",Vshow)
这个代码涉及——str(num):num 通常是一个整数,用于给保存的图像文件编号,以避免文件名重复。
解读:
路径M:/python/workspace/PythonProject/cv/+编号为数字+文件名包含123+图片格式为jpg
读取视频帧得到图片
文件夹中图片如下:

补充1:这里的路径和下文中所提到的调用任务器路径更改方式一致,需要将把文件名中所有“\”改为“/”建筑兔零基础自学python记录16|实战人脸识别项目——人脸检测05-CSDN博客
补充2:上述路径要存在cv这个文件夹里,所以需要在cv后仍然有/,否则就会存在上一路径里面。
(4) k = cv2.waitKey(1) & 0xFF
& 0xFF 操作:
& 是按位与运算符,0xFF 是十六进制数,对应的二进制表示为 11111111。& 0xFF含义是只保留低 8 位数。
目的是为了和能够对应一个ASCII 码值,ASCII 码值是指英文字母、数字、标点符号和一些控制字符。每个 ASCII 码值对应一个唯一的字符。我们在键盘中常用的大部分字符都是ASCII 码值。
这里的代码需要和下一行代码一起解读:
k = cv2.waitKey(1) & 0xFF
if k == ord('s'):
waitkey为等待代码,1为时间,单位为毫秒(ms)。这里我们会发现视频放的很快,如果想慢一点可以改为更大的数,如果改为0则不会自动播放。
整个代码的意思就是按下S则结束等待,执行循环命令
(5) print("success to save"+str(num)+".jpg")
print("-------------------")
num += 1
解读:print命令都是在控制栏里显示结果
print("success to save"+str(num)+".jpg")
"success to save":这是一个固定的字符串,用于告知用户图像保存操作成功。
整个代码的含义为通过字符串拼接操作 +,将这三部分组合成一个完整的提示信息,例如 "success to save1.jpg",然后将其输出到控制台。
print("-------------------")
这行代码同样使用 print() 函数输出一条分隔线,即 19 个连字符 -。分隔线的作用是在每次保存操作的提示信息下方进行分隔,使输出更加清晰易读,方便用户区分不同的保存操作信息。
控制台信息可见:

num += 1
这是一个复合赋值语句,其作用是将变量 num 的值加 1,用于更新保存图像的编号,确保下次保存的图像文件名不会重复。如下图:

(6)import cv2
这和我们之前用的import cv2 as cv不同,都是OpenCV的导入方式,两者都可用。区别在于import cv2后所有cv开头的代码都需要是cv2,不然无法识别。而import cv2 as cv有cv开头的代码都是cv。例如:


补充:如果我们查到一个别人写的代码,cv和cv2混用了,代码报错。如果混用的地方特别多可以z直接在开头输入两个命令,这样就都能运行了。

(7)循环解读
while (cap.isOpened()):
cap.isOpened() 是 cv2.VideoCapture 类的一个方法,用于检查视频捕获对象是否成功打开。它返回一个布尔值:
-
如果视频捕获对象成功打开(例如摄像头正常工作或视频文件可以正常读取),则返回
True。 -
如果视频捕获对象未能成功打开(例如摄像头设备不存在、视频文件路径错误或文件损坏),则返回
False。
elif语句elif是 Python 中的条件分支语句,用于在if条件不满足时,进一步检查其他条件。
综上我们解读一下整段代码:import cv2 # 读视频 cap = cv2.VideoCapture('test1.mp4') num = 1 #循环命令检测视频是否成功打开 while (cap.isOpened()): #从视频里读出:读帧与否和图像 ret_flag, Vshow = cap.read() #将图像以窗口的形式展示出来 cv2.imshow("Capture_Test", Vshow) #按下S则结束等待,执行循环命令 k = cv2.waitKey(50) & 0xFF if k == ord('s'): #图面保存路径、用数字编号 cv2.imwrite("D:mycodetest/opencv/data/jm/" + str(num) + ".123" + ".jpg", Vshow) #新增图像编号+1 num += 1 #按下S后控制栏中显示success to save1.jpg,每行之间用-------分隔 print("success to save" + str(num) + ".jpg") print("-------------------") #按空格则终止 elif k == ord(' '): break # 释放视频 cap.release() cv2.destroyAllWindows()
全部代码讲的就是:读视频,按s截图,空格中止。
整个代码可分解为以下几大部分:

总结:
cv.imshow() 将图像数据以窗口的形式展示出来
cv.imwrite()将图像保存到文件
按键S
k = cv2.waitKey(1) & 0xFF
if k == ord('s'):
import cv2
import cv2 as cv
while
if
elif


1534

被折叠的 条评论
为什么被折叠?



