欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年08月17日 10:09:37   作者:Amo Xiang  
這篇文章主要介紹了Python使用urlretrieve實現(xiàn)直接遠(yuǎn)程下載圖片的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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

下面我們再來看看 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會生成一個臨時文件保存數(shù)據(jù)。)

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

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

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

import urllib
def 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%%' % per
url = 'http://www.google.com'
local = 'd://google.html'
urllib.urlretrieve(url, local, cbk)

代碼實現(xiàn)

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

import requests
import urllib.request
import 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ò)請求 獲取響應(yīng)
  if response.status_code == 200: # 判斷請求是否成功
    # 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)命名圖片名稱
      urllib.request.urlretrieve(img_path, "img_download/" + "img" + str(index) + ".jpg")
  else:
    print("請求失敗")


if __name__ == '__main__':
  download_pictures("https://ch.jd.com/hotsale2?cateid=686")

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

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

相關(guān)文章

  • 如何配置關(guān)聯(lián)Python 解釋器 Anaconda的教程(圖解)

    如何配置關(guān)聯(lián)Python 解釋器 Anaconda的教程(圖解)

    這篇文章主要介紹了如何配置關(guān)聯(lián)Python 解釋器 Anaconda的教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)火鍋工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • Python小程序爬取今日新聞拿走就能用

    Python小程序爬取今日新聞拿走就能用

    這篇文章主要教大家怎樣實現(xiàn)一個Python小程序,爬取今日新聞,文中給出了詳細(xì)的示例代碼,拿走就能用,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • Scrapy爬蟲實例講解_?;ňW(wǎng)

    Scrapy爬蟲實例講解_?;ňW(wǎng)

    下面小編就為大家?guī)硪黄猄crapy爬蟲實例講解_校花網(wǎng)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • tensorflow2.0與tensorflow1.0的性能區(qū)別介紹

    tensorflow2.0與tensorflow1.0的性能區(qū)別介紹

    今天小編就為大家分享一篇tensorflow2.0與tensorflow1.0的性能區(qū)別介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • 詳解Python中的字符串格式化

    詳解Python中的字符串格式化

    這篇文章主要為大家介紹了Python中的字符串格式化,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Python devel安裝失敗問題解決方案

    Python devel安裝失敗問題解決方案

    這篇文章主要介紹了Python devel安裝失敗問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-06-06
  • Python?count()函數(shù)用法詳解

    Python?count()函數(shù)用法詳解

    這篇文章主要給大家介紹了關(guān)于Python?count()函數(shù)用法的相關(guān)資料,Python?count()方法用于統(tǒng)計字符串里某個字符出現(xiàn)的次數(shù),可選參數(shù)為在字符串搜索的開始與結(jié)束位置,需要的朋友可以參考下
    2024-02-02
  • Python利用turtle庫繪制彩虹代碼示例

    Python利用turtle庫繪制彩虹代碼示例

    這篇文章主要介紹了Python利用turtle庫繪制彩虹代碼示例,具有一定借鑒價值,需要的朋友可以參考下。
    2017-12-12
  • PyTorch搭建CNN實現(xiàn)風(fēng)速預(yù)測

    PyTorch搭建CNN實現(xiàn)風(fēng)速預(yù)測

    PyTorch是一個開源的Python機(jī)器學(xué)習(xí)庫,基于Torch,用于自然語言處理等應(yīng)用程序。它不僅能夠?qū)崿F(xiàn)強(qiáng)大的GPU加速,同時還支持動態(tài)神經(jīng)網(wǎng)絡(luò)。本文將介紹PyTorch搭建CNN如何實現(xiàn)風(fēng)速預(yù)測,感興趣的可以學(xué)習(xí)一下
    2021-12-12
  • python實現(xiàn)代碼統(tǒng)計程序

    python實現(xiàn)代碼統(tǒng)計程序

    這篇文章主要為大家詳細(xì)介紹了python實現(xiàn)代碼統(tǒng)計程序,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09

最新評論