python實現文件下載的方法總結

前端時間遇到一個經過url下載文件的需求,只須要簡單的編寫一個py腳本便可。從網上搜了下python實現文件下載的方法,總結以下,備查。前端

如下方法均已測試,環境win8.1  python2.6/2.7python

 

方法一:服務器

使用 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/1302861code

方法二:

使用urllib的urlopen()函數

實例:

import urllib2
print "downloading with urllib2"
url = 'http://.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://ww.pythontab.com/test/demo.zip' 
r = requests.get(url) 
with open("demo3.zip", "wb") as code:
     code.write(r.content)
相關文章
相關標籤/搜索