Уроки Python 14 - Скачивание файлов
компьютерная программа по информатике и икт

Кликодуев Владимир Валерьевич

Уроки Python 14 - Скачивание файлов

 

Скачать:

ВложениеРазмер
Файл uroki_python_14.docx19.78 КБ

Предварительный просмотр:

Уроки Python 14 - Скачивание файлов

Сегодня мы научимся скачивать файлы из интернета двумя разными способами. Первый способ предполагает использование модуля под названием wget, и он достаточно хорош для больших файлов. Второй способ использует библиотеку requests, и применяется в основном для сохранения картинок с сайтов. Дело в том, что некоторые сайты ограничивают скачивание картинок с помощью библиотеки wget. Именно поэтому при сохранении html страниц с картинками, приходится использовать вместо wget библиотеку requests. Также понадобится модуль shutil который не нужно ставить, он входит в стандартную поставку модулей Python.

Давайте установим оба модуля:

pip install wget

pip install requests 

Теперь давайте попробуем скачать какой-либо файл с помощью модуля wget. Пусть это будет например картинка с моего сайта.

Код программы (обратите внимание что в коде я заменил расширение картинки jpg на jbg - при копировании кода замените обратно):

import wget, os

s='pic/20170413081151825.jbg'

filename = wget.download(s)

os.rename(filename, u''+os.getcwd()+'/'+filename)

Для начала мы поместили адрес скачиваемого файла в переменную s. Далее с помощью команды filename = wget.download(s) мы скачали файл и сохранили его под временным именем, которое поместилось в переменную filename. Теперь, чтобы сохранить в файл под тем именем, которое нам нужно, задействуем модуль os, и дадим команду os.rename(filename, u''+os.getcwd()+filename), которая переместит временный файл в папку, где лежит наш скрипт, сохранив при этом имя файла. Если такой файл там уже существует (например мы запустили скрипт два раза подряд), может возникнуть ошибка, связанная с попыткой перезаписи уже существующего файла, имейте это ввиду.

Теперь скачаем тот же самый файл с помощью библиотеки requests.

import requests, shutil, os

s='pic/20170413081151825.jbg'

(dirname, filename) = os.path.split(s)

r = requests.get(s, stream=True)

if r.status_code == 200:

    with open(filename, 'wb') as f:

        r.raw.decode_content = True

        shutil.copyfileobj(r.raw, f)

Разберем данный код. Сначала мы как обычно помещаем адрес файла, который нужно скачать в переменную s. Далее нам нужно выделить из этого адреса имя файла, под которым мы будем его сохранять. Для этого дадим команду (dirname, filename) = os.path.split(s), которая разделит адрес файла на путь к нему и собственно имя файла, которое нам и нужно. Теперь с помощью get запроса из модуля requests получим файл в переменную r, указав в параметрах запроса stream=true, что означает потоковое сохранение принимаемых данных в файл. Если сервер вернет нам статус 200, что свидетельствует об успешном соединении, с помощью функции open откроем на запись файл с именем filename в режиме записи байтов - 'wb'. И далее с помощью команды shutil.copyfileobj(r.raw, f) скопируем принимаемый поток собственно в файл. Как видим, такой способ немного сложнее чем вариант с wget, но зато он срабатывает в большинстве случаев.


По теме: методические разработки, презентации и конспекты

Уроки Python 1 - Переменные и их типы

Уроки Python 1 - Переменные и их типы...

Уроки Python 2 - Условный оператор if-else

Уроки Python 2 - Условный оператор if-else...

Уроки Python 3 - Сложные условия

Уроки Python 3 - Сложные условия...

Уроки Python 4 - Списки и циклы

Уроки Python 4 - Списки и циклы...

Уроки Python 5 - "Первая программа"

Уроки Python 5 - Первая программа...

Уроки Python 6 - Работа со строками

Уроки Python 6 - Работа со строками...

Уроки Python 9 - Файлы, запись, чтение

Уроки Python 9 - Файлы, запись, чтение...