SyntaxError: неверный синтаксис при попытке освободить веб-камеру - PullRequest
1 голос
/ 07 ноября 2019

Я написал код, который планируется выполнять для распознавания лиц, глаз и улыбки путем захвата кадров с веб-камеры моего ноутбука. Однако, когда я закончу, приведенный ниже код не запускается и возвращает неверную синтаксическую ошибку. Я не знаю, как решить эту проблему, потому что строка возвращает ошибку точно так же везде в Интернете, как и я. Но все же я могу где-то что-то делать не так. (Кстати, я новичок в Python!)

import cv2
import sys
import numpy as np

face_classifier = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
eye_classifier = cv2.CascadeClassifier('haarcascade_eye.xml')
smile_classifier = cv2.CascadeClassifier('haarcascade_smile.xml')

video_capture = cv2.VideoCapture(0)   

img_counter = 0

while True:
    #Capture frame by frame
    _, frame = video_capture.read()
    im_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    k = cv2.waitKey(1)

    #Detect faces, eyes and smiles in input frame
     faces = face_classifier.detectMultiScale(im_gray, 
                                              scaleFactor = 1.5, 
                                              minNeighbors = 5,
                                              minSize=(30, 30),
                                            flags=cv2.CASCADE_SCALE_IMAGE)

     eyes = eye_classifier.detectMultiScale(im_gray, 
                                            scaleFactor = 1.5,
                                            minNeighbors = 3,
                                            minSize=(10, 10),
                                            maxSize=(15,15),
                                          flags = cv2.CASCADE_SCALE_IMAGE)

     smiles = smile_classifier.detectMultiScale(im_gray,
                                                scaleFactor = 1.5,
                                                minNeighbors = 3,
                                                minSize = (5,5),
                                                maxSize = (10,15),
                                         flags = cv2.CASCADE_SCALE_IMAGE)

    # Draw a rectangle around the faces
    for x, y, w, h in faces:
        cv2.rectangle(frame, (x, y), (x+w, y+h), (0, 255, 0), 2)

    # Draw a rectangle around the eyes
    for ex, ey, ew, eh in eyes:
        cv2.rectangle(frame, (ex, ey), (ex+ew, ey+eh), (0,0,255), 1)         

        # Draw a rectangle around the smiles    
        for fx,fy,fw,fh in smiles:
            cv2.rectangle(frame, (fx,fy), (fx+fw, fy+fh), (110,100,200), 1.5)

            # Display the resulting frame
            cv2.imshow('Our Face Detector', frame)

            if k == 27: #ESC Pressed
                break
            elif k == 32: # SPACE pressed
                img_name = "FaceDetect_webcam_{}.png".format(img_counter)
                cv2.imwrite(img_name,frame)
                print("{} saved!".format(img_name, frame)
                img_counter += 1
video_capture.release()
cv2.destroyAllWindows()

Вот ошибка 1:

File "C:\ProgramData\Anaconda3\lib\site-packages\spyder_kernels\customize\spydercustomize.py", line 827, in runfile
execfile(filename, namespace)

File "C:\ProgramData\Anaconda3\lib\site-packages\spyder_kernels\customize\spydercustomize.py", line 110, in execfile
exec(compile(f.read(), filename, 'exec'), namespace)

File "C:/Users/User/Desktop/Top Secret/EE 492/ANACONDA-PYTHON-OPENCV/untitled0.py", line 69
img_counter += 1
          ^
SyntaxError: invalid syntax

Вотошибка 2:

File "<ipython-input-21-a9c9ddf625b0>", line 64
video_capture.release()
     ^
SyntaxError: invalid syntax

1 Ответ

0 голосов
/ 07 ноября 2019

В этой строке:

print ("{} сохранено!". Формат (имя_кадра, фрейм)

(как указано в комментарии) a ")"отсутствует.

Кроме того, в той же строке синтаксис использования" .format () "равен не правильно , поскольку вы указали две переменные внутри скобок" .format ", а именно:img_name "и" frame ", но в" print "есть только один" {} ". Так что должно быть два "{}", если вы хотите вывести значения двух переменных. Обратите внимание, что это не приведет к возникновению какой-либо ошибки, а только к ее указанию.

Надеюсь, это поможет.

edit:

Проверьте отступ в вашем коде.

После

k = cv2.waitKey(1)

перед строкой "face = face_classifier ..... "есть пробел. (Я не знаю, произошло ли это при вставке кода здесь, или это было так в вашем редакторе)

Кроме того, я не думаю, что вам нужно вложить этот цикл внутри предыдущего цикла. Должен быть в пределах «отступа цикла»

для см. Fy, fy, fw, fh в смайлах: cv2.rectangle (frame, (fx, fy), (fx + fw, fy + fh), (110,100,200), 1,5)

Затем поместите следующие следующие строки кода также в «отступ цикла»

Итак, в конечном итоге ваш код будет выглядеть так:

while True:
    #Capture frame by frame
    _, frame = video_capture.read()
    im_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    k = cv2.waitKey(1)

    #Detect faces, eyes and smiles in input frame
    faces = face_classifier.detectMultiScale(im_gray, 
                                          scaleFactor = 1.5, 
                                          minNeighbors = 5,
                                          minSize=(30, 30),
                                        flags=cv2.CASCADE_SCALE_IMAGE)

    eyes = eye_classifier.detectMultiScale(im_gray, 
                                        scaleFactor = 1.5,
                                        minNeighbors = 3,
                                        minSize=(10, 10),
                                        maxSize=(15,15),
                                      flags = cv2.CASCADE_SCALE_IMAGE)

    smiles = smile_classifier.detectMultiScale(im_gray,
                                            scaleFactor = 1.5,
                                            minNeighbors = 3,
                                            minSize = (5,5),
                                            maxSize = (10,15),
                                     flags = cv2.CASCADE_SCALE_IMAGE)

    # Draw a rectangle around the faces
    for x, y, w, h in faces:
        cv2.rectangle(frame, (x, y), (x+w, y+h), (0, 255, 0), 2)

    # Draw a rectangle around the eyes
    for ex, ey, ew, eh in eyes:
        cv2.rectangle(frame, (ex, ey), (ex+ew, ey+eh), (0,0,255), 1)         

    # Draw a rectangle around the smiles    
    for fx,fy,fw,fh in smiles:
        cv2.rectangle(frame, (fx,fy), (fx+fw, fy+fh), (110,100,200), 1.5)

    # Display the resulting frame
    cv2.imshow('Our Face Detector', frame)

    if k == 27: #ESC Pressed
        break
    elif k == 32: # SPACE pressed
        img_name = "FaceDetect_webcam_{}.png".format(img_counter)
        cv2.imwrite(img_name,frame)
        print("{} saved!".format(img_name, frame)
        img_counter += 1
video_capture.release()

cv2.destroyAllWindows()
...