目前我有一个脚本, 从帝联的 CDN 外链获取一下文件作为备份.
使用的是
Python 2.7.10
requests 2.8.1
目前碰到一个情况, 使用 requests 下载大文件的时候会出现下载文件不完整的情况, 出现的概率非常大, 应该不会是网络原因导致的. 相关代码概括如下:
requests.adapters.DEFAULT_RETRIES = 5
response = requests.get(url, stream=True)
status = response.status_code
if status == 200:
total_size = int(response.headers['Content-Length'])
with open('xxx', 'wb') as of:
for chunk in response.iter_content(chunk_size=102400):
if chunk:
of.write(chunk)
下载完毕后我会使用如下方式和上面的 total_size 进行对比
with open('xxx', 'r') as f:
if isinstance(f, file):
length = os.fstat(f.fileno()).st_size
if total_size == length:
True
else:
False
代码逻辑如上. 但是对于 100M 以上的文件, 几乎都是保存在本地的文件和获取的响应头里面的 content-length 不一致.
是我 requests 的用法不对吗? 还是有其他更好的办法可以保证文件能完整的下载呢?
找到文章,可以很好的解決requests下載不完整的問題:https://www.jianshu.com/p/f92704c42b49
主要用到了response.raw.tell()和response .headers.get('Content-Length')
網路本來就是不穩定的,下載大檔案時網路中斷是很正常的事情,只要你有一定的機率成功就可能是網路的問題。
解決方法就是下載後比較大小,如果不完整就斷點續傳。參考:python 編寫斷點續傳下載軟體
另一種方法是呼叫 curl 之類支援斷點續傳的下載工具。
樓主有解決這個問題麼,同遇到了,沒有報任何錯誤,幾M的文件都下載不完整,用法和你一樣