Загрузите и распакуйте файл с помощью Python

Я пытаюсь загрузить и открыть заархивированный файл и, похоже, проблема с дескриптором типа файла с zipfile. Я получаю сообщение об ошибке «AttributeError: экземпляр addinfourl не имеет атрибута« искать »при запуске:

import zipfile import urllib2 def download(url,directory,name): webfile = urllib2.urlopen('http://www.sec.gov'+url) webfile2 = zipfile.ZipFile(webfile) content = zipfile.ZipFile.open(webfile2).read() localfile = open(directory+name, 'w') localfile.write(content) localfile.close() return() download(link.get("href"),'./fails_data', link.text) 

Вы не можете искать файл urllib2.urlopen ed. Поддерживаемые методы перечислены здесь: http://docs.python.org/library/urllib.html#urllib.urlopen .

Вам нужно будет восстановить файл (возможно, с urllib.urlretrieve , http://docs.python.org/library/urllib.html#urllib.urlretrieve ), а затем использовать zipfile .

Кроме того, вы можете read() файл urlopen ed, а затем поместить его в StringIO , а затем использовать zipfile , если хотите получить данные в zip- zipfile в памяти. Также проверьте методы extract и extract_all zipfile если вы просто хотите извлечь файл, вместо использования read .

Соединяя вещи, следующее получает содержимое первого файла в zip-файле с веб-сайта:

 import urllib import zipfile url = 'http://www.gutenberg.lib.md.us/4/8/8/2/48824/48824-8.zip' filehandle, _ = urllib.urlretrieve(url) zip_file_object = zipfile.ZipFile(filehandle, 'r') first_file = zip_file_object.namelist()[0] file = zip_file_object.open(first_file) content = file.read()