一、环境是Windows下,python3.5,openCv选择opencv_python‑3.3.1+contrib‑cp35‑cp35m‑win_amd64.whl (一定要选择cp35的,电脑64位就选择64的)
openCv下载地址https://www.lfd.uci.edu/~gohlke/pythonlibs/#opencv
(其他方法可以下载openCv到本地,将opencv里的cv2.pyd拷贝到python\Lib\site-package文件夹后。但是我这样操作后还是存在同样的问题。尝试了各种办法均以失败告终。
后来了解到可能是python和opencv版本不兼容的问题,于是删除了opencv文件,下载了对应于python3.5的opencv。我的python是3.5.3所以opencv对应选择cp35的版本 opencv_python-3.2.0+contrib-cp35-cp35m-win_amd64.whl(这里需要注意如果python安装的是32位的版本那么opencv也应该选择32位的版本,否则opencv会安装失败)。
把下载好的.whl拷贝到python\Lib\site-packages文件夹。开始菜单cmd进入命令窗口然后使用pip进行安装,安装命令为:pip install opencv_python-3.2.0+contrib-cp35-cp35m- win_amd64.whl安装成功后,问题解决。)
二、openCv小试牛刀(附赠openCv教程)
1显示图片(两种方式,一种用matplotlib,一种用openCv)
2.调用摄像头识别人脸
运用的技术有opencv(摄像头、图片处理),numpy(图片数字化),os(文件的操作和处理),keras(构建神经网络进行图像识别)。
1读取图片、视频
2灰度转换:灰度转换的作用就是:转换成灰度的图片的计算强度得以降低
3画图
4显示图像
5获取人脸识别训练数据
6探测人脸
1 import numpy as np
2 import cv2
3 import sys
4
5 def CatVideo():
6 cv2.namedWindow("shibie")
7 #1调用摄像头
8 cap=cv2.VideoCapture(0)
9 #2人脸识别器分类器 Train.xml可以自行下载,也可以去我git下载,地址稍后发布
10 classfier=cv2.CascadeClassifier("Train.xml")
11 color=(0,255,0)
12 while cap.isOpened():
13 ok,frame=cap.read()
14 if not ok:
15 break
16 #3灰度转换
17 grey=cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
18 #4人脸检测,1.2和2分别为图片缩放比例和需要检测的有效点数
19 faceRects = classfier.detectMultiScale(grey, scaleFactor = 1.2, minNeighbors = 3, minSize = (32, 32))
20 if len(faceRects) > 0: #大于0则检测到人脸
21 print("测试1")
22 for faceRect in faceRects: #单独框出每一张人脸
23 x, y, w, h = faceRect #5画图
24 cv2.rectangle(frame, (x - 10, y - 10), (x + w + 10, y + h + 10), color, 3)
25 cv2.imshow("shibie",frame)
26 print("ceshi2")
27 if cv2.waitKey(10)&0xFF==ord('q'):
28 break
29
30 cap.release()
31 cv2.destroyAllWindows()
32
33
34
35 CatVideo()
git地址:https://github.com/chaoyuebeijita/face.git