python-3.x - OpenCV Python Numpy:ValueError:要解压的值太多(预期为 2)
问题描述
我正在尝试将图像裁剪到轮廓的边界。我从这个答案中找到了一个代码
mask = np.zeros_like(image)
cv2.drawContours(mask, [c], -1, 255, -1)
out = np.zeros_like(image)
out[mask == 255] = image[mask == 255]
(y, x) = np.where(mask == 255)
(topy, topx) = (np.min(y), np.min(x))
(bottomy, bottomx) = (np.max(y), np.max(x))
out = out[topy: bottomy + 1, topx:bottomx + 1]
crop_img = image[topy: bottomy + 1, topx:bottomx + 1]
cv2.imshow("croppedd", crop_img)
哪里c
是轮廓。
我收到如下错误:
Traceback (most recent call last):
File "detect_shapes.py", line 66, in <module>
(y, x) = np.where(mask == 255)
ValueError: too many values to unpack (expected 2)
我该如何解决我的问题?
- Python 3.7 版
- OpenCV 版本 3.4.4
我认为这与我的形象无关,但这里是我的形象;
解决方案
您上面提到的答案是grayscale
使用模式加载图像
image = cv2.imread('...', 0)
这里0
指的是cv2.IMREAD_GRAYSCALE
flag。这很重要,因为在这种情况下,image
将只有1
通道。如果您以这种方式加载图像并运行代码,它将正常工作。我已经测试过了。在这种情况下,(y, x) = np.where(mask == 255)
不会给出任何错误,因为输出np.where(mask == 255)
是两个 numpy 数组的元组,因为mask
它是一个2d
数组(使用检查mask.shape
)。
但是,如果您将图像加载为image = cv2.imread('...')
而不是image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
将其转换为灰度,那么在这种情况下,np.where(mask == 255)
将三个 numpy 数组的元组作为此处mask
的3d
数组返回这就是您遇到上述错误的原因。
推荐阅读
- java - 如何使用 Java API 将数据插入数据库?
- scala - Promise 优于 Try 的用法
- reactjs - 反应原生 - Redux
- visual-studio - 如何在 Visual Studio IDE 中调试慢速输入?
- vb.net - VB.NET 如何从 DataGridView 更新数据源(绑定到 Dataset.DataTable)
- javascript - 反应原生点击登录后如何添加底部选项卡菜单
- reactjs - useState 不会改变 React 中的状态
- r - 在 R 中创建许多新的数据框
- python - TensorFlow 安装问题
- java - 基于标签java字符串数组搜索项目