我正在编写一个脚本,它将自动更新已安装的Calibre版本。目前我正在下载最新的便携版本。我似乎在保存zipfile时遇到了麻烦。目前我的代码是:
import urllib2
import re
import zipfile
#tell the user what is happening
print("Calibre is Updating")
#download the page
url = urllib2.urlopen ( "http://sourceforge.net/projects/calibre/files" ).read()
#determin current version
result = re.search('title="/[0-9.]*/([a-zA-Z\-]*-[0-9\.]*)', url).groups()[0][:-1]
#download file
download = "http://status.calibre-ebook.com/dist/portable/" + result
urllib2.urlopen( download )
#save
output = open('install.zip', 'w')
output.write(zipfile.ZipFile("install.zip", ""))
output.close()发布于 2012-01-11 14:02:24
为此,您不需要使用zipfile.ZipFile (而且您使用它的方式以及urllib2.urlopen也有问题)。相反,您需要将urlopen结果保存在一个变量中,然后将其read并将输出写入.zip文件。尝试以下代码:
#download file
download = "http://status.calibre-ebook.com/dist/portable/" + result
request = urllib2.urlopen( download )
#save
output = open("install.zip", "w")
output.write(request.read())
output.close()发布于 2012-01-11 14:28:55
还可以使用一行代码:
open('install.zip', 'wb').write(urllib.urlopen('http://status.calibre-ebook.com/dist/portable/' + result).read())它的内存效率不是很高,但仍然可以工作。
发布于 2012-01-11 14:02:33
如果你只是想从网上下载一个文件,你可以使用urllib.urlretrieve
将由URL表示的网络对象复制到本地文件...
使用requests代替urllib2的示例
import requests, re, urllib
print("Calibre is updating...")
content = requests.get("http://sourceforge.net/projects/calibre/files").content
# determine current version
v = re.search('title="/[0-9.]*/([a-zA-Z\-]*-[0-9\.]*)', content).groups()[0][:-1]
download_url = "http://status.calibre-ebook.com/dist/portable/{0}".format(v)
print("Downloading {0}".format(download_url))
urllib.urlretrieve(download_url, 'install.zip')
# file should be downloaded at this pointhttps://stackoverflow.com/questions/8814813
复制相似问题