[python]解决urllib.urlretrieve()下载不完全的问题

问题:

    我们使用urllib.urlretrieve(url,filename)时经常遇到下载到一半时,出现urllib.ContentTooShortError错误。
    这是因为文件下载不完全导致的错误。
    如果发现问题的是诸如图片和音乐文件这一类文件较小的问题,可以很容易使用以下方式解决。

解决:

    我们可以使用捕捉错误解决这个问题,例如:
try:
        urllib.urlretrieve(url,filename)
    except urllib.ContentTooShortError:
        print 'Network conditions is not good.Reloading.'
        urllib.urlretrieve(url,filename)
    但是这种方法在网路很不稳定时,依然会抛出错误,这是因为第二次重新下载时依然出现下载不完全的情况。
    我们可以使用 递归 的方法,即每次下载不完全时重新下载解决这个问题。
def auto_down(url,filename):
    try:
        urllib.urlretrieve(url,filename)
    except urllib.ContentTooShortError:
        print 'Network conditions is not good.Reloading.'
        auto_down(url,filename)
    我们可以使用自己定义的auto_down()来代替python的urllib.urlretrieve()函数,实现我们自动重新下载的目标。
    tips:新下载的文件会覆盖原来下载不完全的文件。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值