urllib.request.urlretrieve()用於下載制定url內容到本地


函數:urllib.urlretrieve(url[, filename[, reporthook[, data]]]) 
參數說明: 
url:外部或者本地url ,url中不要含有中文,好像會出錯。
filename:指定了保存到本地的路徑(如果未指定該參數,urllib會生成一個臨時文件來保存數據); 
reporthook:是一個回調函數,當連接上服務器、以及相應的數據塊傳輸完畢的時候會觸發該回調。我們可以利用這個回調函數來顯示當前的下載進度。 
data:指post到服務器的數據。該方法返回一個包含兩個元素的元組(filename, headers),filename表示保存到本地的路徑,header表示服務器的響應頭。 

抓取百度首頁進行保存的例子如下:

 1 from urllib import request
 2 def fun(blocknum,blocksize,totalsize):
 3     """
 4     blocknum:當前的塊編號
 5     blocksize:每次傳輸的塊大小
 6     totalsize:網頁文件總大小
 7     """
 8     percent = blocknum*blocksize/totalsize
 9     if percent > 1.0:
10         percent = 1.0
11     percent = percent*100
12     print("download : %.2f%%" %(percent))
13 url = "http://www.baidu.com"
14 path = r"C:\Users\Administrator\Desktop\download\sina.html"
15 request.urlretrieve(url, path, fun)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM