Python:为什么urllib.request.urlopen.read()从未完成下载?

时间:2020-02-18 16:33:00

标签: python request

我有代码:

from urllib.request import urlopen
url = 'http://gmsh.info/bin/MacOSX/gmsh-4.5.2-MacOSX-sdk.tgz'
sdk = urlopen(url).read()

和问题:为什么此下载永不结束?链接正常,并且可以在浏览器中使用。我试图设置一些这样的标题:

from urllib import request
req = request.Request(url)
req.add_header('user-agent', "Mozilla/5.0 (X11; U; Linux i686) Gecko/20071127 Firefox/2.0.0.11")
sdk = request.urlopen(req).read()

但这没有帮助。有什么想法吗?

1 个答案:

答案 0 :(得分:1)

这是因为文件很大,请尝试将其下载成块。 如示例所示,它将起作用。 import urllib.request filedata = urllib.request.urlopen('http://gmsh.info/bin/MacOSX/gmsh-4.5.2-MacOSX-sdk.tgz') CHUNK = 1 * 1024 with open('test.zip', 'wb') as f: while True: chunk = filedata.read(CHUNK) if not chunk: break f.write(chunk)

相关问题