【问题标题】:opencv TypeError: 'int' object is not iterableopencv TypeError:'int'对象不可迭代
【发布时间】:2018-09-29 04:47:42
【问题描述】:

我正在尝试使用 OpenCV 检测人脸。我有一个文件 recognizer.py 如下:

import cv2

faceDetect = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
cam = cv2.VideoCapture(0)
rec = cv2.face.createLBPHFaceRecognizer()
rec.load('recognizer/trainningData.yml')
id = 0
font = cv2.FONT_HERSHEY_SIMPLEX
while True:
    ret, img = cam.read()
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    faces = faceDetect.detectMultiScale(gray, 1.3, 5)
    for (x, y, w, h) in faces:
        cv2.rectangle(img, (x, y), (x + w, y + h), (0, 0, 255), 2)
        id, conf = rec.predict(gray[y:y + h, x:x + w])
        cv2.putText(img, str(id), (x, y + h), font, 255, (255, 0, 0))
    cv2.imshow("Face", img)
    if cv2.waitKey(1) == ord('q'):
        break
cam.release()
cv2.destroyAllWindows()

当我尝试运行此代码时,程序运行成功并打开了一个摄像头窗口。

但每当我试图在镜头前露脸时,程序都会以退出代码 1 终止并显示以下错误:

Traceback (most recent call last):
  File "/home/prateek/recognizer.py", line 15, in <module>
    id, conf = rec.predict(gray[y:y + h, x:x + w])

TypeError: 'int' object is not iterable

Process finished with exit code 1

意思是,我在 第 15 行 收到如下错误:

id, conf = rec.predict(gray[y:y + h, x:x + w])

我不知道如何解决这个问题。我正在使用 Python3OpenCV3.3

【问题讨论】:

  • 如果你能在 Jupyter notebook 中演示这个问题,也许在 Google Colaboratory 上
  • 好了,你知道问题陈述了,那么做一些调试怎么样?比如说,调查你在那里使用的所有变量的值?

标签: python python-3.x opencv opencv3.3


【解决方案1】:

最后,我找到了解决方案。问题是opencv的版本。此代码适用于 opencv2.4,我试图在 opencv3 上运行它。

嗯,opencv3的最终代码如下:

import cv2

faceDetect = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
cam = cv2.VideoCapture(0)
rec = cv2.face.createLBPHFaceRecognizer()
rec.load('recognizer/trainningData.yml')
id = 0
font = cv2.FONT_HERSHEY_SIMPLEX
while True:
    ret, img = cam.read()
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    faces = faceDetect.detectMultiScale(gray, 1.3, 5)
    for (x, y, w, h) in faces:
        cv2.rectangle(img, (x, y), (x + w, y + h), (0, 0, 255), 2)
        id= rec.predict(gray[y:y + h, x:x + w])
        cv2.putText(img, str(id), (x, y + h), font, 255, (255, 0, 0))
    cv2.imshow("Face", img)
    if cv2.waitKey(1) == ord('q'):
        break
cam.release()
cv2.destroyAllWindows()

变量conf就不用提了。

rec.predict(gray[y:y + h, x:x + w]) 正在从数据库id /strong>。

【讨论】:

    猜你喜欢
    • 2017-09-11
    • 1970-01-01
    • 2023-01-22
    • 2020-02-26
    • 2015-04-06
    • 2013-10-31
    • 2018-03-14
    相关资源
    最近更新 更多