问题:
1 | 我们使用request.urlretrieve(url,filename)时经常遇到下载到一半时,出现urllib.ContentTooShortError错误。 |
解决:
我们可以使用捕捉错误解决这个问题,例如:
1 | try: |
但是这种方法在网路很不稳定时,依然会抛出错误,这是因为第二次重新下载时依然出现下载不完全的情况。
我们可以使用 递归 的方法,即每次下载不完全时重新下载解决这个问题。
1 | def auto_down(url,filename): |
我们可以使用自己定义的auto_down()来代替python的urllib.request.urlretrieve()函数,实现我们自动重新下载的目标。
tips:新下载的文件会覆盖原来下载不完全的文件。