```python
import cv2
import numpy as np
# 读取图像
image = cv2.imread('image.jpg')
# 转换为灰度图像
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
# 通过阈值化将图像转换为二值图像
_, thresh = cv2.threshold(gray, 150, 255, cv2.THRESH_BINARY)
# 找到轮廓
contours, _ = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
# 创建一个黑色背景的图像
mask = np.zeros_like(gray)
# 绘制轮廓到mask中
cv2.drawContours(mask, contours, -1, (255), thickness=cv2.FILLED)
# 将mask应用到原始图像中
result = cv2.bitwise_and(image, image, mask=mask)
# 保存结果
cv2.imwrite('result.png', result)
```
这段代码首先读取一张图像,然后将其转换为灰度图像。接着通过阈值化将图像转换为二值图像,并找到图像的轮廓。然后创建一个黑色背景的图像,绘制轮廓到这个图像中。最后将这个mask应用到原始图像中,得到抠图后的结果。