admin 28 июня 2018

3 самых важных сферы применения Python: возможности языка

Существует множество областей применения Python, но в некоторых он особенно хорош. Разбираемся, что же можно делать на этом ЯП.

Сферы применения Python

Если вы собираетесь изучать Python или совсем недавно начали его учить, вы точно задумывались, что же можно на нем сделать. Вопрос не простой, так как этот язык используется во многих сферах.

Но можно выделить 3 самых популярных направления применения Python:

  1. веб-разработка;
  2. data science: машинное обучение, анализ данных и визуализация;
  3. автоматизация процессов.

Каждое из них заслуживает отдельного рассмотрения.

Веб-разработка

Относительно недавно в веб-разработке стали очень популярны Python-фреймворки, такие как Django и Flask. Они облегчают процесс написания на языке Python кода серверной части приложений. Это тот код, который запускается на сервере, а не на устройствах и браузерах пользователей (frontend-код). Если вы не знакомы с отличиями backend- и frontend-разработки, вам будет интересна заметка в конце статьи.

Зачем нужен веб-фреймворк?

Фреймворки позволяют легко и быстро создать базовую логику бэкенда. Она включает в себя сопоставление разных URL-адресов с частями Python-кода, работу с базами данных, создание HTML-представлений для отображения на устройствах пользователя.

Какой Python-фреймворк выбрать?

Django и Flask – два самых популярных веб-фреймворка, созданных для языка Python. Новичку следует выбрать один из них.

В чем разница между Django и Flask?

Разницу отлично описывает цитата из великолепной статьи Flask vs. Django (Gareth Dwyer):

Основные отличия:

  • Flask обеспечивает простоту, гибкость и полный контроль над проектом. Он позволяет пользователю самостоятельно решать, как реализовывать те или иные вещи.
  • Django – это сервис типа "все включено". Из коробки в нем уже есть админ-панель, интерфейсы баз данных, ORM (объектно-реляционное отображение) и структура каталогов для ваших проектов.

Что выбрать?

  • Выбирайте Flask, если хотите получить больше опыта и возможностей для обучения. Или в том случае, если вам нужен максимальный контроль над всеми используемыми компонентами, например, базами данных.
  • Выбирайте Django, если вас интересует конечный продукт. Особенно, если вы работаете с простыми приложениями, такими как новостной сайт, магазин, блог, и хотите, чтобы каждая задача решалась одним предельно ясным способом.

Другими словами, Flask – это, возможно, лучший выбор для начинающего разработчика, так как он содержит меньше компонентов. Кроме того, его стоит выбрать, если необходима тонкая настройка проекта.

Flask из-за своей гибкости лучше подходит для создания REST API.

С другой стороны, если стоит задача сделать что-то просто и быстро, вероятно, стоит выбрать Django.

Data Science: машинное обучение, анализ данных и визуализация

Прежде всего, следует разобраться, что такое машинное обучение.

Предположим, что вы хотите разработать программу, которая будет автоматически определять, что изображено на картинке.

Например, предлагая ей это изображение, вы хотите, чтобы программа опознала собаку.

Изображение собаки для алгоритма машинного обучения

А здесь она должна увидеть стол.

Изображение стола для алгоритма машинного обучения

Возможно, вы думаете, что для решения этой задачи можно просто написать код анализа изображения. Например, если на картинке много светло-коричневых пикселей, делаем вывод, что это собака.

Или вы можете научиться определять на изображении края и границы. Тогда картинка с большим количеством прямых границ, вероятно, окажется столом.

Однако это довольно сложный и непродуманный подход. Что делать, если на фотографии изображена белая собака без коричневых пятен? Или если на картинке круглый стол?

Здесь вступает в игру машинное обучение. Обычно оно реализует некоторый алгоритм, который позволяет автоматически обнаруживать знакомый шаблон среди входных данных.

Вы можете предложить алгоритму машинного обучения, скажем, 1000 изображений собаки и 1000 снимков столов. Он выучит разницу между этими объектами. Затем, когда вы дадите ему новую картинку со столом или собакой, он сможет определить, что именно на ней изображено.

Это очень похоже на то, как учатся маленькие дети. Каким именно образом они узнают, что одна вещь похожа на стол, а другая – на собаку? Из большого количества примеров.

Вы ведь не даете ребенку четкую инструкцию: "Если нечто пушистое и светло-каштановое, значит, это собака". Напротив, вы говорите: "Это собака. Это тоже собака. И это. А это стол. И это тоже стол".

Алгоритмы машинного обучения в основном работают сходным образом.

Эта технология может применяться:

  • в рекомендательных сервисах (вспомните, например, YouTube, Amazon и Netflix);
  • в системах распознавания лиц и голосов.

Среди самых популярных алгоритмов машинного обучения, о которых вы, вероятно, слышали:

Любой из вышеперечисленных алгоритмов может быть использован для решения задачи с собаками и столами на изображениях.

Способы применения Python для машинного обучения

Существуют разные библиотеки и фреймворки для машинного обучения на Python. Две самые популярные – это scikit-learn и TensorFlow.

  • scikit-learn из коробки имеет несколько встроенных популярных алгоритмов обучения;
  • TensorFlow – это более низкоуровневая библиотека. Она позволяет создавать пользовательские алгоритмы.

Новичкам в машинном обучении лучше начать со scikit-learn. Более опытным разработчикам, которые столкнулись с проблемами эффективности, стоит присмотреться к TensorFlow.

Как изучать машинное обучение?

Для ознакомления с основами предмета прекрасно подойдут курсы Стэнфорда или Калтеха (Калифорнийский технический институт). Следует отметить, что для понимания материала требуются базовые знания в области математического анализа и линейной алгебры.

Затем можно переходить к практике на платформе Kaggle. Это сайт, на котором исследователи в области data science создают различные алгоритмы машинного обучения для решения реальных проблем. Победители получают солидные денежные призы. У них также есть отличные учебники для начинающих.

Анализ и визуализация данных

Чтобы понять, о чем идет речь, следует обратиться к простому примеру.

Предположим, вы работаете аналитиком данных в компании, которая продает товары через Интернет. Вы можете получить такую гистограмму:

Анализ и визуализация данных на Python

Из этого графика можно понять, что в это воскресенье мужчины купили более 400 единиц продукта, а женщины – около 350. Ваша задача, как аналитика, придумать несколько возможных объяснений такой разницы.

Один из очевидных вариантов заключается в том, что этот продукт больше популярен у мужчин, чем у женщин. Другое объяснение может быть связано со слишком маленьким размером выборки, который привел к недостоверным результатам. Третий вариант – мужчины по какой-либо причине склонны покупать продукт по воскресеньям.

Чтобы разобраться, в чем дело, вы можете просмотреть данные за всю неделю и составить новый график.

Анализ и визуализация данных на Python

Из схемы видно, что различие довольно устойчиво и проявляется не только по воскресеньям.

Можно сделать вывод, что наиболее убедительным объяснением является принципиально большая заинтересованность мужчин в этом продукте.

С другой стороны, график за неделю может выглядеть вот так.

Анализ и визуализация данных на Python

Как здесь объяснить большую разницу в продажах в воскресенье?

Вы можете предположить, что мужчины в конце недели почему-то склонны покупать больше. Или это может оказаться простым совпадением.

Это упрощенный пример того, как выглядит реальный анализ данных.

Настоящие аналитики, например, в Google или Microsoft, делают то же самое, только их работа более сложная и комплексная.

Они используют язык запросов SQL, чтобы извлекать данные из баз. Затем для анализа и визуализации применяются специальные инструменты, например, Mathplotlib (для Python) или D3.js (для JavaScript).

Способы применения Python для анализа и визуализации данных

Одна из самых популярных библиотек для визуализации – Mathplotlib.

Новичкам следует начинать обучение с нее по двум причинам:

  • низкий порог вхождения;
  • освоение Mathplotlib позволит в будущем быстрее разобраться в более сложных библиотеках, основанных на ней, например, seaborn.

Как изучать анализ данных на Python?

Сначала следует изучить основы. Вот хорошее видео, посвященное данной теме:

Закрепить знания поможет курс по визуализации данных на Pluralsight. Получить его бесплатно можно, подписавшись на 10-дневную пробную версию.

Чтобы разобраться в основах статистики, пройдите курсы на Coursera и Khan Academy.

Автоматизация процессов

Одна из самых популярных сфер применения Python – это написание небольших скриптов для автоматизации различных рабочих операций и процессов.

В качестве примера можно привести систему обработки электронной почты. Для сбора статистики и анализа данных требуется подсчитывать количество входящих писем, содержащих определенные ключевые слова. Это можно делать вручную, или же написать простой скрипт, который все посчитает сам.

Есть несколько причин применения Python для задач автоматизации:

  • простой синтаксис, позволяющий быстро писать сценарии;
  • легкость отладки, связанная с тем, что код не компилируется перед запуском.

Встроенные приложения

Python является самым популярным языком программирования для Raspberry Pi.

Python и игры

Несмотря на то, что существует библиотека PyGame, популярность применения Python для создания игр невелика. Для серьезных проектов он не подходит.

Чтобы создавать хорошие мультиплатформенные игры, стоит присмотреться к одному из самых популярных движков Unity, работающем с языком C#.

Десктопные приложения

Вы можете создать парочку, используя Tkinter, но это не самое популярное решение.

Для этой задачи лучше использовать такие языки, как Java, C# и C++.

С недавних пор некоторые компании начали использовать для создания настольных приложений JavaScript. Например, десктопное приложение Slack было создано с помощью JavaScript-фреймворка Electron.

Преимущество написания настольных приложений на JavaScript заключается в том, что можно повторно использовать код веб-версии.

Python 3 или Python 2

Python 3 – это более современный и популярный выбор.

Пояснение о backend- и frontend-коде

Предположим, вы хотите сделать нечто, напоминающее Инстаграм.

Вам необходимо создать frontend-код для каждого типа устройств, который должен поддерживаться. Для этого могут использоваться разные языки программирования, например:

  • Swift для iOS;
  • Java для Android;
  • JavaScript для веб-браузеров.

На каждом типе устройства будет запускаться свой набор кода. Он определит формат приложения, его внешний вид и т.д.

Однако вам требуется хранить личные данные и фотографии. Вы хотите использовать для этого свой сервер, а не устройства пользователей, чтобы подписчики могли просматривать фотографии друг друга.

Для решения этой задачи потребуется backend-код (server-side). Он будет выполнять следующие операции:

  • Отслеживать добавления в друзья и подписки;
  • Сжимать фотографии, чтобы они занимали меньше места при хранении;
  • Анализировать запросы и выдавать рекомендации каждому пользователю.

В этом и заключается разница между frontend- и backend-кодом.
Python – это не единственный хороший выбор для написания серверного кода. Есть множество других популярных вариантов, среди которых Node.js, основанный на JavaScript.

Перевод статьи What exactly can you do with Python? Here are Python’s 3 main applications (автор YK Sugi).

МЕРОПРИЯТИЯ

Комментарии

ЛУЧШИЕ СТАТЬИ ПО ТЕМЕ