未在opencv python中保存视频

未在opencv python中保存视频,python,opencv,Python,Opencv,我传递一个视频作为输入,抓取的视频作为输出。输出显示在窗口中,但最后抛出属性错误,视频文件以给定名称保存,但为空文件 我问了很多类似的问题,我尝试了所有的答案,但结果都是一样的。有人能告诉我这个代码有什么错误吗 import imutils import numpy as np import argparse import cv2 ap = argparse.ArgumentParser() ap.add_argument("-v", "--video", help="

我传递一个视频作为输入,抓取的视频作为输出。输出显示在窗口中,但最后抛出属性错误,视频文件以给定名称保存,但为空文件

我问了很多类似的问题,我尝试了所有的答案,但结果都是一样的。有人能告诉我这个代码有什么错误吗

import imutils
import numpy as np
import argparse
import cv2

ap = argparse.ArgumentParser()
ap.add_argument("-v", "--video",
            help="path to the (optional) video file")
args = vars(ap.parse_args())


lower = np.array([0, 0, 20], dtype="uint8")
upper = np.array([25, 255, 255], dtype="uint8")


if not args.get("video", False):
   camera = cv2.VideoCapture('videos/15-IMG_1090.MOV')

   fourcc = cv2.VideoWriter_fourcc(*'XVID')
   out = cv2.VideoWriter('output.avi',fourcc, 20.0, (640,480))


else:
   camera = cv2.VideoCapture('videos/15-IMG_1093.MOV')

   fourcc = cv2.VideoWriter_fourcc(*'XVID')
   out = cv2.VideoWriter('output.avi',fourcc, 20.0, (640,480))


 while True:
   # grab the current frame
   (grabbed, frame) = camera.read()

   if args.get("video") and not grabbed:
      break


   # resize the frame, convert it to the HSV color space,
   # and determine the HSV pixel intensities that fall into
   # the speicifed upper and lower boundaries

   frame = imutils.resize(frame, width=500)
   converted = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
   skinMask = cv2.inRange(converted, lower, upper)


   kernel = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (11, 11))
   skinMask = cv2.erode(skinMask, kernel, iterations=2)
   skinMask = cv2.dilate(skinMask, kernel, iterations=2)


   skinMask = cv2.GaussianBlur(skinMask, (3, 3), 0)
   skin = cv2.bitwise_and(frame, frame, mask=skinMask)


   out.write(skin)
   cv2.imshow("images", np.hstack([frame, skin]))

   # if the 'q' key is pressed, stop the loop
   if cv2.waitKey(1) & 0xFF == ord("q"):
      break


camera.release()
out.release()
cv2.destroyAllWindows()
这里是错误

Traceback (most recent call last):
  File "E:/Harshitha/python learning/python/video_analysis/new_code_grab.py", line 60, in <module>
    frame = imutils.resize(frame, width=500)
  File "C:\Users\Harshitha\Anaconda3\lib\site-packages\imutils\convenience.py", line 69, in resize
    (h, w) = image.shape[:2]
AttributeError: 'NoneType' object has no attribute 'shape'
回溯(最近一次呼叫最后一次):
文件“E:/Harshitha/python learning/python/video\u analysis/new\u code\u grab.py”,第60行,在
frame=imutils.resize(frame,width=500)
文件“C:\Users\Harshitha\Anaconda3\lib\site packages\imutils\concility.py”,第69行,调整大小
(h,w)=图像形状[:2]
AttributeError:“非类型”对象没有属性“形状”
请任何人帮助我修复错误并保存新抓取的视频。
谢谢。

看起来像照相机中的“帧”。read()为无。你能确认它确实没有吗?你们能在camera.read()行之前打印camera.open()并查看它是真是假吗?如果这是错误的,您可以在网上找到多个资源。这可能是由于opencv+python、ffmpeg或不支持的格式安装不兼容造成的。我已经打印了帧,正在打印值,但最后显示为无。相机也在打印值。即使我也打印了“抓取”,这将一直实现到最后,正如我所说的,帧将变为无,抓取将变为假。如果抓取为假,则不会转到“imutils.resize(frame,width=500)”行。args.get(“视频”)的值是多少?这是真的吗?是的,这是真的,但在视频的最后,它出了问题,它给出了错误。直到最后视频播放正确,而结束时抛出错误。甚至我也尝试过删除“if args.get(“video”)和not grapped:break”,但也有同样的错误。在“if args.get(“video”)和not grapped:break”行之后添加“if frame is None:break”行行是否有效?很明显,你的错误来了,因为帧是无的。