我正在尝试像PHP函数一样从字符串加载图像 imagecreatefromstring
我怎样才能做到这一点?
我有MySQL Blob字段图像。我正在使用MySQLdb,并且不想在PyOpenCV中创建用于处理图像的临时文件。
注意:需要cv(不是cv2)包装函数
这就是我通常用来将数据库中存储的图像转换为Python中的OpenCV图像的方式。
import numpy as np
import cv2
from cv2 import cv
# Load image as string from file/database
fd = open('foo.jpg')
img_str = fd.read()
fd.close()
# CV2
nparr = np.fromstring(img_str, np.uint8)
img_np = cv2.imdecode(nparr, cv2.CV_LOAD_IMAGE_COLOR) # cv2.IMREAD_COLOR in OpenCV 3.1
# CV
img_ipl = cv.CreateImageHeader((img_np.shape[1], img_np.shape[0]), cv.IPL_DEPTH_8U, 3)
cv.SetData(img_ipl, img_np.tostring(), img_np.dtype.itemsize * 3 * img_np.shape[1])
# check types
print type(img_str)
print type(img_np)
print type(img_ipl)
我已经添加了从numpy.ndarray
到的转换cv2.cv.iplimage
,因此上面的脚本将显示:
<type 'str'>
<type 'numpy.ndarray'>
<type 'cv2.cv.iplimage'>
编辑:从最新numpy开始1.18.5 +
,np.fromstring
提出警告,因此np.frombuffer
应在该位置使用。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句