色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python使用urlretrieve實(shí)現(xiàn)直接遠(yuǎn)程下載圖片的示例代碼

瀏覽:2日期:2022-07-13 17:44:17

在實(shí)現(xiàn)爬蟲(chóng)任務(wù)時(shí),經(jīng)常需要將一些圖片下載到本地當(dāng)中。那么在python中除了通過(guò)open()函數(shù),以二進(jìn)制寫(xiě)入方式來(lái)下載圖片以外,還有什么其他方式嗎?本文將使用urlretrieve實(shí)現(xiàn)直接遠(yuǎn)程下載圖片。

下面我們?cè)賮?lái)看看 urllib 模塊提供的 urlretrieve() 函數(shù)。urlretrieve() 方法直接將遠(yuǎn)程數(shù)據(jù)下載到本地。

>>> help(urllib.urlretrieve)Help on function urlretrieve in module urllib: urlretrieve(url, filename=None, reporthook=None, data=None)

參數(shù) finename 指定了保存本地路徑(如果參數(shù)未指定,urllib會(huì)生成一個(gè)臨時(shí)文件保存數(shù)據(jù)。)

參數(shù) reporthook 是一個(gè)回調(diào)函數(shù),當(dāng)連接上服務(wù)器、以及相應(yīng)的數(shù)據(jù)塊傳輸完畢時(shí)會(huì)觸發(fā)該回調(diào),我們可以利用這個(gè)回調(diào)函數(shù)來(lái)顯示當(dāng)前的下載進(jìn)度。

參數(shù) data 指 post 到服務(wù)器的數(shù)據(jù),該方法返回一個(gè)包含兩個(gè)元素的(filename, headers)元組,filename 表示保存到本地的路徑,header 表示服務(wù)器的響應(yīng)頭。

下面通過(guò)例子來(lái)演示一下這個(gè)方法的使用,這個(gè)例子將 google 的 html 抓取到本地,保存在 D:/google.html 文件中,同時(shí)顯示下載的進(jìn)度。

import urllibdef cbk(a, b, c): ’’’回調(diào)函數(shù) @a: 已經(jīng)下載的數(shù)據(jù)塊 @b: 數(shù)據(jù)塊的大小 @c: 遠(yuǎn)程文件的大小 ’’’ per = 100.0 * a * b / c if per > 100: per = 100 print ’%.2f%%’ % perurl = ’http://www.google.com’local = ’d://google.html’urllib.urlretrieve(url, local, cbk)

代碼實(shí)現(xiàn)

在python中除了使用open()函數(shù)實(shí)現(xiàn)圖片的下載,還可以通過(guò)urllib.request模塊中的urlretrieve實(shí)現(xiàn)直接遠(yuǎn)程下載圖片的操作。以遠(yuǎn)程下載某網(wǎng)頁(yè)外設(shè)產(chǎn)品圖片為例,代碼如下:

import requestsimport urllib.requestimport os # 系統(tǒng)模塊import shutil # 文件夾控制def download_pictures(url): headers = { 'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) ' 'AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.129 Safari/537.36'} response = requests.get(url, headers=headers) # 發(fā)送網(wǎng)絡(luò)請(qǐng)求 獲取響應(yīng) if response.status_code == 200: # 判斷請(qǐng)求是否成功 # print(response.json()) # 每次獲取數(shù)據(jù)之前,先將保存圖片的文件夾清空 在創(chuàng)建目錄 if os.path.exists('img_download'): # 判斷文件夾是否存在 shutil.rmtree('img_download') # 存在則刪除 os.makedirs('img_download') # 重新創(chuàng)建 else: os.makedirs('img_download') # 不存在 直接創(chuàng)建 content = response.json()['products'] # 獲取響應(yīng)內(nèi)容 print(content) for index, item in enumerate(content): # 圖片地址 img_path = 'http://img13.360buyimg.com/n1/s320x320_' + item['imgPath'] # print(item['imgPath']) # 根據(jù)下標(biāo)命名圖片名稱(chēng) urllib.request.urlretrieve(img_path, 'img_download/' + 'img' + str(index) + '.jpg') else: print('請(qǐng)求失敗')if __name__ == ’__main__’: download_pictures('https://ch.jd.com/hotsale2?cateid=686')

運(yùn)行結(jié)果如下圖所示:

Python使用urlretrieve實(shí)現(xiàn)直接遠(yuǎn)程下載圖片的示例代碼

到此這篇關(guān)于Python使用urlretrieve實(shí)現(xiàn)直接遠(yuǎn)程下載圖片的示例代碼的文章就介紹到這了,更多相關(guān)Python urlretrieve遠(yuǎn)程下載內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 国产一区免费观看 | 日本aaa毛片| 美女黄页网站免费进入 | 日本高清在线不卡 | 在线观看亚洲成人 | 国产成人精品在视频 | 欧美一级高清片欧美国产欧美 | 午夜性a一级毛片 | 亚洲欧美日韩在线一区 | 久久久免费精品 | 99精品国产在现线免费 | 亚洲天堂2015 | aaa在线观看高清免费 | 欧美成人乱弄视频 | 欧美成人久久久 | 男操女视频网站 | 手机看片在线精品观看 | 亚洲视频在线一区二区 | 欧美高清免费精品国产自 | 天堂中文资源在线8 | 欧美激情综合亚洲五月蜜桃 | 国产成人影院在线观看 | 久久精品6 | 俄罗斯美女在线观看一区 | 欧美激情久久久久久久久 | 亚洲成人精品久久 | 精品国产欧美一区二区五十路 | 中文字幕亚洲精品久久 | 毛片免费观看视频 | 草草影院在线观看 | 日韩亚洲在线 | 国产精品正在播放 | 久久精品九九 | 日韩在线二区 | 国产午夜精品理论片 | 一级毛片不卡片免费观看 | 亚洲天堂影院在线观看 | 日本久草网 | 色偷偷亚洲第一成人综合网址 | 成年人网站免费观看 | 亚洲精品一区二区三区美女 |