python - 我正在尝试使用 OpenCV 的项目,但无法克服此错误
问题描述
cv2.error: OpenCV(4.4.0) C:\Users\appveyor\AppData\Local\Temp\1\pip-req-build-2y91i_7w\opencv\modules\objdetect\src\cascadedetect.cpp:1689: error: (-215:Assertion failed) !empty() in function 'cv::CascadeClassifier::detectMultiScale'
[ WARN:0] global C:\Users\appveyor\AppData\Local\Temp\1\pip-req-build-2y91i_7w\opencv\modules\videoio\src\cap_msmf.cpp (435) `anonymous-namespace'::SourceReaderCB::~SourceReaderCB terminating async callback
这是我面临的错误
下面是我的代码
import cv2
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
smile_cascade = cv2.CascadeClassifier('haarcascade_smile.xml')
def detect(gray,frame):
faces = face_cascade.detectMultiScale(gray, 1.3, 5)
for (x,y,w,h) in faces:
cv2.rectangle(frame, (x,y), ((x+w),(y+h)), (2555,0,0), 2)
roi_gray = gray[y:y + h, x:x + w]
roi_color = frame[y:y + h, x:x +w]
smiles = smile_cascade.detectMultiScale(roi_gray, 1.8,20)
for (sx,sy,sw,sh) in smiles:
cv2.rectangle(roi_color ,(sx,sy), ((sx + sw) , (sy + sh)),(0,0,225),2)
return frame
video_capture = cv2.VideoCapture(0)
while True:
_, frame = video_capture.read()
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
canvas = detect(gray, frame)
cv2.imshow('Video', canvas)
if cv2.waitkey(1) & xff == qrd('q'):
break
video_capture.release()
cv2.destroyAllWindows()
解决方案
我得到了一个不同的错误并修复了方法return
行的缩进detect()
,请参阅注释。
此外,函数存在一些错误waytkey()
,实际上是waitKey()
.
这应该有效(至少它在我的机器上有效):
import cv2
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
smile_cascade = cv2.CascadeClassifier('haarcascade_smile.xml')
def detect(gray, frame):
faces = face_cascade.detectMultiScale(gray, 1.3, 5)
for (x,y,w,h) in faces:
cv2.rectangle(frame, (x,y), ((x+w),(y+h)), (2555,0,0), 2)
roi_gray = gray[y:y + h, x:x + w]
roi_color = frame[y:y + h, x:x +w]
smiles = smile_cascade.detectMultiScale(roi_gray, 1.8,20)
for (sx,sy,sw,sh) in smiles:
cv2.rectangle(roi_color ,(sx,sy), ((sx + sw) , (sy + sh)),(0,0,225),2)
return frame # << outdent
video_capture = cv2.VideoCapture(0)
while True:
ret, frame = video_capture.read()
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
canvas = detect(gray, frame)
cv2.imshow('Video', canvas)
# changed here below the waitKey() and added ret:
keypressed = cv2.waitKey(10)
if keypressed == ord('q') or not ret:
break
video_capture.release()
cv2.destroyAllWindows()
推荐阅读
- java - selenium 在版本 91.0.4472.101 中为任何给定的 url 引发 InvalidArgumentException
- ffmpeg - 检测部分帧的场景变化
- react-native - React Native:如何使第二行文本居中
- php - Docusign ClickWrap API
- python - 如何根据行索引创建文件多列的列表?
- jekyll - 我想要在 jekyll 中的当前年份和给定年份之间有所不同
- android - 在 AutoCompleteTextView 适配器中选择了错误的项目
- amazon-web-services - AWS SQS:如何检查是否处理了多条消息
- c++ - 图像拼接大战透视尺寸问题
- javascript - 目标域事件未触发?