【问题标题】:OpenCV 3.4.0.12 with Python3.5 AttributeError: 'cv2.VideoCapture' object has no attribute 'imread'带有 Python3.5 AttributeError 的 OpenCV 3.4.0.12:“cv2.VideoCapture”对象没有属性“imread”
【发布时间】:2018-06-21 06:19:24
【问题描述】:

我第一次尝试使用 python 3.5 和 OpenCV 3.4.0.12 进行面部识别,运行代码时出现此错误。

  File "/Users/connorwoodford/anaconda3/envs/chatbot/lib/python3.5/site-packages/spyder/utils/site/sitecustomize.py", line 101, in execfile
    exec(compile(f.read(), filename, 'exec'), namespace)

  File "/Users/connorwoodford/Desktop/temp.py", line 11, in <module>
    ret, img = cap.imread()

AttributeError: 'cv2.VideoCapture' object has no attribute 'imread'

代码:

import cv2
import numpy as np

face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')

eye_cascade = cv2.CascadeClassifier('CascadeClassifier')

cap = cv2.VideoCapture(0)

while True:
    ret, img = cap.read()
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    faces = face_cascade.detectMultiScale(gray, 1.3, 5)
    for(x,y,w,h) in faces:
        cv2.rectangle(img, (x+y), (x+w, y+h), (255,0,0), 2)
        roi_gray = gray[y:y+h, x:x+w]
        roi_color = img[y:y+h, x:x+w]
        eyes = eye_cascade.detectMultiScale(roi_gray)
        for (ex,ey,ew,eh) in eyes:
            cv2.rectangle(roi_color, (ex, ey), (ex+ew,ey+eh), (0,255,0), 2)

    cv2.imshow('img',img)
    k = cv2.waitkey(30) & 0xff
    if k == 27:
        break

cap.release()
cv2.destroyAllWindows()

【问题讨论】:

  • 添加错误的完整回溯将是最有帮助的
  • 您的错误与您的代码不匹配。您的错误有ret, img = cap.imread(),但您的代码有ret, img = cap.read()。您的代码是正确的,但错误表明您的代码有 cap.imread() 而不是 cap.read()。也没有 OpenCV 3.4.0.12。有 2.4.12 和 3.4.0。

标签: python numpy opencv face-recognition


【解决方案1】:

您的 eye_cascade 引用了错误的级联文件,它应该以 .xml 扩展名结尾。你可以从这里下载它haarcascade_eye.xml

另请注意,您对 cv2.rectangle 的调用格式不正确。

改成

cv2.rectangle(img, (x+y), (x+w, y+h), (255,0,0), 2)

cv2.rectangle(img, (x,y), (x+w,y+h), (255,0,0), 2)

完成这项工作所需要做的就是将捕获逻辑包装在一个方法中。完整代码如下:

import numpy as np
import cv2

def sample_demo():

    face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
    eye_cascade = cv2.CascadeClassifier('haarcascade_eye.xml')

    cap = cv2.VideoCapture(0)

    while 1:
        ret, img = cap.read()

        gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
        faces = face_cascade.detectMultiScale(gray, 1.3, 5)

        for (x,y,w,h) in faces:
            cv2.rectangle(img,(x,y),(x+w,y+h),(255,0,0),2)
            roi_gray = gray[y:y+h, x:x+w]
            roi_color = img[y:y+h, x:x+w]

            eyes = eye_cascade.detectMultiScale(roi_gray)
            for (ex,ey,ew,eh) in eyes:
                cv2.rectangle(roi_color,(ex,ey),(ex+ew,ey+eh),(0,255,0),2)

        cv2.imshow('img',img)
        k = cv2.waitKey(30) & 0xff
        if k == 27:
            break

    cap.release()
    cv2.destroyAllWindows()

只需调用方法 sample_demo()

sample_demo()

【讨论】:

    猜你喜欢
    • 2018-05-31
    • 2021-06-11
    • 2022-06-10
    • 2017-05-11
    • 2020-12-25
    • 2020-03-14
    • 2021-01-25
    • 2019-03-11
    • 2018-02-20
    相关资源
    最近更新 更多