我有一个程序,保存在本地目录中的图像,然后从该目录中读取图像。
但我不希望保存的图像。 我想直接从URL中读取它。
这里是我的代码:
import cv2.cv as cv
import urllib2
url = "http://cache2.allpostersimages.com/p/LRG/18/1847/M5G8D00Z/posters/curious-cat.jpg"
filename = "my_test_image" + url[-4:]
print filename
opener = urllib2.build_opener()
page = opener.open(url)
img= page.read()
abc = open(filename, "wb")
abc.write(img)
abc.close()
img = cv.LoadImage(filename)
cv.ShowImage("Optical Flow", img)
cv.WaitKey(30)
如果我将其更改为:
img = cv.LoadImage(img)
这会给我这个错误:
参数1必须是没有空字节字符串,而不是str的
我能做什么?
如果你愿意,你可以使用PIL。
import cv2.cv as cv
import urllib2
from cStringIO import StringIO
import PIL.Image as pil
url="some_url"
img_file = urllib2.urlopen(url)
im = StringIO(img_file.read())
source = pil.open(im).convert("RGB")
bitmap = cv.CreateImageHeader(source.size, cv.IPL_DEPTH_8U, 3)
cv.SetData(bitmap, source.tostring())
cv.CvtColor(bitmap, bitmap, cv.CV_RGB2BGR)
我想通过这个方法,你并不需要保存图像文件。
import numpy as np
import urllib
import cv2
def url_to_image(url):
response = urllib.urlopen(url)
image = np.asarray(bytearray(response.read()), dtype="uint8")
cv2_img = cv2.imdecode(image, cv2.IMREAD_COLOR)
return cv2_img
如前所述这里的LoadImage期待文件名作为第一个参数,而不是数据