您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關python怎么獲取網頁中所有圖片并篩選指定分辨率的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
1、簡單易用,與C/C++、Java、C# 等傳統語言相比,Python對代碼格式的要求沒有那么嚴格;2、Python屬于開源的,所有人都可以看到源代碼,并且可以被移植在許多平臺上使用;3、Python面向對象,能夠支持面向過程編程,也支持面向對象編程;4、Python是一種解釋性語言,Python寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序;5、Python功能強大,擁有的模塊眾多,基本能夠實現所有的常見功能。
壓測時,圖片太少,想著下載網頁中的圖片,然后過濾指定分辨率,但網頁中指定分辨率的圖片太少了(見下)
后使用格式工廠轉換圖片
import urllib.request # 導入urllib模塊 import re # 導入re模塊 import os from PIL import Image htmlurl = 'http://www.win4000.com/wallpaper_detail_134824_3.html' downloadpath = 'C:\\Users\\yaowanjun\\Desktop\\img\\' def getHTML(htmlurl): req = urllib.request.urlopen(htmlurl) buf = req.read() return buf.decode('utf-8') def downloadImg(buf): req = r'src="(.+?\.jpg)"' #正則表達式,匹配圖片格式 imgreq = re.compile(req) #編譯正則表達式 imglist = re.findall(imgreq, buf) # print(imglist) x = 0 if not os.path.isdir(downloadpath):#若沒有則創建 os.makedirs(downloadpath) paths = downloadpath for imgurl in imglist: f = open(paths + str(x) +'.jpg',"wb") #打開文件 req = urllib.request.urlopen(imgurl) buf = req.read() #讀出文件 f.write(buf) f.close() x = x + 1 return imglist def saveImg(): for filenumber in os.walk(downloadpath): # print(filenumber[2]) for files in filenumber[2]: # print(files) singleimg = Image.open(downloadpath + files) singleimg.close() #print(singleimg.size, singleimg.width, singleimg.height) if singleimg.size == (1920, 1080): print(singleimg) else: os.remove(downloadpath + files) buf = getHTML(htmlurl) downloadImg(buf) saveImg()
執行結果:
指定網頁所有圖片
不符合指定分辨率的圖片刪除后
感謝各位的閱讀!關于“python怎么獲取網頁中所有圖片并篩選指定分辨率”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。