不論是用OpenCV還是PIL,skimage等庫,在之前做圖像處理的時(shí)候,幾乎都是讀取本地的圖片。最近嘗試爬蟲爬取圖片,在保存之前,我希望能先快速瀏覽一遍圖片,然后有選擇性的保存。這里就需要從url讀取圖片了。查了很多資料,發(fā)現(xiàn)有這么幾種方法,這里做個(gè)記錄。
本文用到的圖片URL如下:
img_src = 'http://wx2.sinaimg.cn/mw690/ac38503ely1fesz8m0ov6j20qo140dix.jpg'
1.用OpenCV
OpenCV的imread()只能加載本地的圖片,并不能通過網(wǎng)址加載圖片。但是,opencv的VideoCapture類可以從url加載視頻。如果只用opencv的話,我們可以一個(gè)迂回的方式:先用VideoCapure加載網(wǎng)址下的圖片,然后再傳給Mat。
1
2
3
4
5
6
|
import cv2 cap = cv2.VideoCapture(img_src) if ( cap.isOpened() ) : ret,img = cap.read() cv2.imshow( "image" ,img) cv2.waitKey() |
2. OpenCV+Numpy+urllib
1
2
3
4
5
6
7
8
|
import numpy as np import urllib import cv2 resp = urllib.urlopen(img_src) image = np.asarray(bytearray(resp.read()), dtype = "uint8" ) image = cv2.imdecode(image, cv2.IMREAD_COLOR) cv2.imshow( "Image" , image) cv2.waitKey( 0 ) |
urlopen返回 一個(gè)類文件對(duì)象,它提供了如下方法:
read() , readline() , readlines() , fileno() , close() :這些方法的使用方式與文件對(duì)象完全一樣。然后把返回的類文件對(duì)象重新編碼,轉(zhuǎn)換為圖片傳給Mat。
3.PIL+requests
1
2
3
4
5
6
|
import requests as req from PIL import Image from io import BytesIO response = req.get(img_src) image = Image. open (BytesIO(response.content)) image.show() |
requests能以字節(jié)的方式訪問請(qǐng)求響應(yīng)體,以上就是以請(qǐng)求返回的二進(jìn)制數(shù)據(jù)創(chuàng)建一張圖片的代碼。
4. skimage
1
2
3
4
|
from skimage import io image = io.imread(img_src) io.imshow(image) io.show() |
相對(duì)來說,這種方式應(yīng)該是最簡單的,因?yàn)閟kimage可以直接以imread()函數(shù)來讀取網(wǎng)頁圖片,而不需要其他的輔助,也不需要迂回。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
原文鏈接:http://blog.csdn.net/xingchenbingbuyu/article/details/71404664