现在有一个收集人脸的需求,每一张照片只有一个人。我的解决办法是用收集录制一段视频,然后上传到PC上。在PC上使用OpenCV将图片中的每一帧保存为JPG图片。
公司主营业务:成都做网站、成都网站设计、成都外贸网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联建站是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联建站推出富源免费做网站回馈大家。
以下是代码:
import time import cv2 if __name__ == '__main__': # 填写视频的绝对路径 vidcap = cv2.VideoCapture('/home/shushi/video/猎场.mp4') success, image = vidcap.read() start_time = time.time() print(start_time) while success: end_time = time.time() file_name = str(end_time).replace('.', '') # 每隔三秒截屏 if 3 == int(end_time - start_time): start_time = end_time # 保存JGP 的绝对路径 cv2.imwrite('/home/shushi/video/' + file_name + ".jpg", image) # save frame as JPEG file success, image = vidcap.read() if cv2.waitKey(10) == 27: # exit if Escape is hit break
将视频放到与Python文件同级目录下,然后运行程序,你就会得到视频帧对应的JPG图片了:
小编再为大家分享一段代码:OpenCV按视频帧进行截取,作者是Haku_yyf
#include#include #include int main(int argc, char **argv) { //打开视频文件 cv::VideoCapture cap("E:\\New folder\\DSC_3543.MOV"); if (!cap.isOpened()) { std::cout << "不能打开视频文件" << std::endl; return -1; } //从3000ms开始播放视频 //cap.set(CV_CAP_PROP_POS_MSEC, 3000); //获取视频的帧速率 double fps = cap.get(cv::CAP_PROP_FPS); double width = cap.get(cv::CAP_PROP_FRAME_WIDTH); double height = cap.get(cv::CAP_PROP_FRAME_HEIGHT); //std::cout << fps << std::endl; //std::cout << width << std::endl; //std::cout << height << std::endl; cv::VideoWriter wrt("C:\\Users\\Administrator\\Desktop\\1.avi", CV_FOURCC('M', 'J', 'P', 'G'), fps, cv::Size(width, height)); int cout = 0; while (true) { cv::Mat frame; //从视频中读取一个帧 bool bSuccess = cap.read(frame); ++cout; if (!bSuccess) { std::cout << "不能从视频文件读取帧" << std::endl; break; } //在MyVideo窗口上显示当前帧 if (cout>=fps*1 && cout<=fps*56)//取视频1-56秒内容 { std::cout << "正在截取..."<<(int)(((cout-fps)/(fps*(56-1)))*100)<<"%" << std::endl; wrt << frame; } if (cout>fps*57) { std::cout << "ENd!!!" << std::endl; break; } } system("pause"); return 0; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。