前端時間遇到一個經過url下載文件的需求,只須要簡單的編寫一個py腳本便可。從網上搜了下python實現文件下載的方法,總結以下,備查。前端
如下方法均已測試,環境win8.1 python2.6/2.7python
待補充。-- 20150507web
方法一:服務器
使用 urllib 模塊提供的 urlretrieve() 函數。urlretrieve() 方法直接將遠程數據下載到本地。函數
urlretrieve(url, [filename=None, [reporthook=None, [data=None]]])
說明:post
參數 finename 指定了保存本地路徑(若是參數未指定,urllib會生成一個臨時文件保存數據。)測試
參數 reporthook 是一個回調函數,當鏈接上服務器、以及相應的數據塊傳輸完畢時會觸發該回調,咱們能夠利用這個回調函數來顯示當前的下載進度。url
參數 data 指 post 到服務器的數據,該方法返回一個包含兩個元素的(filename, headers)元組,filename 表示保存到本地的路徑,header 表示服務器的響應頭。 spa
實例:.net
#!/usr/bin/python #encoding:utf-8 import urllib import os def Schedule(a,b,c): ''''' a:已經下載的數據塊 b:數據塊的大小 c:遠程文件的大小 ''' per = 100.0 * a * b / c if per > 100 : per = 100 print '%.2f%%' % per url = 'http://www.python.org/ftp/python/2.7.5/Python-2.7.5.tar.bz2' #local = url.split('/')[-1] local = os.path.join('/data/software','Python-2.7.5.tar.bz2') urllib.urlretrieve(url,local,Schedule) ######output###### #0.00% #0.07% #0.13% #0.20% #.... #99.94% #100.00%
來源:http://www.nowamagic.net/academy/detail/1302861
方法二:
使用urllib的urlopen()函數
實例:
import urllib2 print "downloading with urllib2" url = 'http://www.pythontab.com/test/demo.zip' f = urllib2.urlopen(url) data = f.read() with open("demo2.zip", "wb") as code: code.write(data)
方法三:
使用requests模塊
requests模塊下載:https://pypi.python.org/pypi/requests/#downloads
實例:
import requests print "downloading with requests" url = 'http://www.pythontab.com/test/demo.zip' r = requests.get(url) with open("demo3.zip", "wb") as code: code.write(r.content)