Flask и Django - это фреймворки для веб-разработки, основанные на Python. В этом учебнике подробно сравниваются Django и Flask. Также кратко рассматривается Flask и Node:
Это всегда было пронизывающей дилеммой, когда речь заходит о выборе фреймворка для вашего следующего проекта. Каждые несколько месяцев вы видите новую технологию и фреймворк, который преодолевает слабость предыдущего, который вы использовали.
Фреймворк больше похож на негласную культуру и набор условностей, которым вы должны следовать, чтобы быть более актуальными и продуктивными в этом постоянно меняющемся мире технологий. Сравнительно недавно веб-разработка продвигалась гораздо быстрее, чем разработка настольных компьютеров.
Django против Flask
В этом учебнике мы подробно рассмотрим сравнение Django и Flask. Flask и Django - это фреймворки для веб-разработки на основе Python. Многие переходят на легкие микрофреймворки. Эти фреймворки являются гибкими, маневренными, небольшими и помогают разрабатывать микросервисы и бессерверные приложения.
Учитывая популярность NodeJS, мы также провели сравнение между Flask и Node в разделе Flask vs. Node. Оценка Django и Flask по следующим характеристикам поможет вам сделать выбор в пользу одного из них.
Администратор по умолчанию
Оба фреймворка предоставляют загружаемое приложение администратора. В Django оно встроено и поставляется с установкой по умолчанию. Однако в случае с Flask вам необходимо установить Flask-Appbuilder, чтобы иметь интерфейс администратора.
Между тем, не забудьте создать суперпользователя в Django и администратора в случае Flask, чтобы вы могли войти в бэкенд администратора через браузер.
Базы данных и ORMS
Django поставляется со встроенным ORM по умолчанию, который полностью поддерживает взаимодействие с такими СУБД, как Oracle, MySQL, PostgreSQL, SQLite и т.д. Этот ORM также поддерживает создание и управление миграциями. Относительно удобнее создавать модели баз данных со встроенными валидациями.
Flask также не навязывает какой-то один конкретный метод и может быть использован с различными расширениями, поддерживающими аналогичные функции, как в случае с Django. Мы привели примеры Flask-SQLAlchemy, Flask-Migrate, Flask-MongoEngine в одном из уроков этой серии.
Виды и маршруты
Оба фреймворка имеют механизмы для объявления представлений на основе методов и классов. В случае Django, маршруты и представления упоминаются в отдельных файлах. Кроме того, нам всегда нужно передавать объект запроса в явном виде.
С другой стороны, во Flask мы можем использовать декоратор для упоминания маршрутов для соответствующих обработчиков. Объект запроса во Flask является глобальным и просто доступен без какой-либо явной передачи. Мы подробно рассмотрели концепции использования представлений и маршрутов в одном из наших учебников.
Формы и шаблоны
Формы Django встроены во фреймворк и не требуют установки. Формы очень важны для приложений, и в Django формы можно передавать в теги шаблонов, и они доступны для отображения в шаблонах. Однако в случае с Flask нам нужно использовать Flask-WTF.
Мы также использовали Flask-Appbuilder для создания форм. Более того, WTF-Alembic можно использовать для генерации HTML-форм на основе моделей баз данных.
Оба фреймворка поддерживают шаблонизацию Jinja2, и оба поддерживают обслуживание статических файлов со встроенными функциями для генерации URL ресурсов, что является довольно распространенным шаблоном во всех фреймворках в наши дни.
Хотя существуют различные способы передачи переменных и отображения шаблонов в их конкретных методах представления, оба фреймворка имеют одинаковый синтаксис доступа к переменным в шаблонах.
Гибкость
Django, из-за своего размера и сложности, менее гибкий, чем Flask. Flask можно легко расширить с помощью огромного количества расширений, которые он поддерживает. Поэтому для настройки Flask требуется больше времени и усилий, потому что нам нужно оценить больше расширений.
Свобода, предоставленная разработчикам, в некотором смысле приводит к замедлению разработки и доставки. С другой стороны, Django следует набору уже установленных конвенций и следует архетипам, которые требуют меньших отклонений от целей и задач проекта.
Кривая обучения
Для изучения Django и Flask требуется почти одинаковое количество времени. Flask имеет меньший API, поэтому люди могут быстрее освоить основной фреймворк. Он становится одинаково сложным, когда дело доходит до использования его расширений. Вскоре он может стать громоздким.
Однако именно потому, что все не упаковано в один пакет, в случае с фреймворком Flask проще практиковать разделение проблем.
Мы рекомендуем вам изучать паттерны, а не синтаксис. И Django, и Flask имеют отличную документацию. Вы можете легко следовать ей во время разработки функции.
Размер и продолжительность проекта
Если вы работаете над большим проектом с большой командой, лучше воспользоваться преимуществами зрелости Django и обширной поддержкой со стороны разработчиков. Если ваш проект меньше и требует меньшего числа разработчиков, лучше выбрать Flask.
Более того, если ваш проект рассчитан на длительную работу, то Django - это правильный выбор; в противном случае вы можете выбрать Flask.
Тип применения
Ранее Django считался правильным выбором, когда требовались полноценные веб-приложения корпоративного масштаба. Но сегодня Flask является не менее зрелой разработкой и может хорошо служить в тех же условиях.
Однако разработчики чаще выбирают Flask для разработки небольших или статичных веб-сайтов, а также при реализации быстродействующих веб-сервисов RESTful API.
Подбор персонала для разработчиков
Наличие квалифицированных ресурсов в области используемого вами фреймворка приносит свои плоды. Вы можете рассчитывать на более быструю разработку, более быстрое тестирование, более быструю доставку и более быстрое устранение проблем.
В случае с Flask найти новых разработчиков довольно легко. Однако в случае с Django найти квалифицированные ресурсы довольно сложно. Готовых к найму разработчиков Django не так много. Более того, фреймворк Django довольно старый, и поэтому большинство новых сотрудников стоят дорого по сравнению с теми, кто обладает навыками работы с фреймворком Flask.
Новые выпускники технических вузов также берут в руки легкие фреймворки, такие как Flask, потому что тенденции отрасли направлены на создание приложений с развязанными микросервисами или технологией, поддерживающей создание бессерверной реализации. Javascript широко используется наряду с фреймворками, которые проще в использовании и более популярны.
Открытый исходный код
И Flask, и Django - проекты с открытым исходным кодом. Django можно найти на //github.com/django/django, а Flask - на //github.com/pallets/flask. Если посмотреть на эти проекты, то количество авторов Django гораздо больше, чем Flask.
Поэтому мы можем рассчитывать на более быструю и качественную поддержку, если у нас возникают проблемы и запросы, требующие решения. Вопреки типичным предположениям, количество пользователей проекта Flask выше, чем у Django.
Один из важных фактов о Flask заключается в том, что может не быть стабильного расширения для конкретной задачи. Поэтому работа по отбору лучшего остается за пользователем расширения.
Например, мы использовали Flask-Twitter-oembedder для работы с API Twitter в прошлом уроке, но у этого расширения были некоторые проблемы, из-за которых нам пришлось перейти с Flask-Cache на Flask-Caching.
Нам даже пришлось включить пользовательский оператор установки, чтобы установить Flask-twitter-oembedder из нашего обновленного репозитория Github, а не упоминать его в файле requrements.txt проекта.
Частое обслуживание - это типичная проблема, с которой вы столкнетесь при работе с проектом с открытым исходным кодом. Поддержка и управление проектом с открытым исходным кодом обычно связаны с платными услугами. Возможно, вам придется долго ждать, чтобы получить исправление нескольких проблем от участников проекта.
Производительность
Фреймворк Flask легче, чем Django, и работает лучше при незначительных различиях, особенно при рассмотрении операций ввода-вывода.
Посмотрите на приведенные ниже сравнения. При увеличении количества запросов производительность Flask остается почти такой же. Однако Django требуется больше времени на отрисовку шаблонов после получения данных с помощью ORM.
Python Flask и Django: табличное сравнение
# | Характеристики | Django | Фляга |
---|---|---|---|
1 | Администратор по умолчанию | Встроенный бэкенд администратора | Установите Flask-Appbuilder |
2 | Включить администратора по умолчанию | В файле settings.py убедитесь, что вы раскомментировали установленное администратором приложение. ... # Определение приложения УСТАНОВЛЕННЫЕ_ПРИЛОЖЕНИЯ = [ 'website', 'django.contrib.admin', # другой код ] ... | Импортируйте AppBuilder и SQLA из flask_appbuilder, сначала инициализируйте БД, а затем Appbuilder из flask import Flask из flask_appbuilder import AppBuilder, SQLA app=Flask(__name__) db = SQLA(app)appbuilder=AppBuilder(app, db.session) |
3 | Создать пользователя-администратора | python manage.py createsuperuser | flask fab create-admin |
4 | Базы данных и ORMS | Встроенный ORM для РСУБД Используйте Django-nonrel для бэкендов NoSQL | Установите Flask-SQLAlchemy Расширение Flask для работы с NoSQL, например, Flask-MongoEngine |
5 | Виды и маршруты | URLConf в urls.py из django.urls import path из .import views urlpatterns = [ path('/path', views.handler_method), # другие урлы и обработчики ] | Используйте декоратор @app.route("/path") на Views, чтобы сопоставить маршрут с функцией. @app.route("/path") def handler_method(): # другой код с дальнейшей логикой |
6 | Шаблоны рендеринга | Во взглядах из django.shortcuts import render def example_view(request): tempvar="value_for_template" return render( запрос, 'demo.html', {'tempvar':tempvar} ) | Во взглядах from . import app из flask import request из flask import render_template @app.route("/path") def demo(): tempvar="value_for_template" return render_template( "demo.html", temp_var=temp_var ) |
7 | Переменная интерполяция в шаблонах | В файле templates/demo.html {{ tempvar }} | В файле templates/demo.html {{ tempvar }} |
8 | Гибкость | Менее гибкий | Более гибкий |
9 | Проектные решения | Меньше решений по проектированию, принимаемых разработчиками. | Больше свободы для разработчиков. |
10 | Отклонение проекта | Меньше отклонений от целей проекта. | Больше отклонений из-за свободы, предоставленной разработчикам. |
11 | Размер кодовой базы | Большая кодовая база | Меньшая кодовая база |
12 | Количество API | Больше API | Меньше API |
13 | Тип применения | Полноценные веб-приложения | Малые приложения / микросервисы |
14 | RESTful приложения | Django REST framework для RESTful приложений. | Используйте следующие расширения для RESTful-приложений. Flask-RESTful Flask-RESTX Присоединение |
15 | Производительность | Медленная производительность при большом количестве запросов. | Постоянная производительность на протяжении всего времени. |
16 | Вклады в открытый исходный код | Большее количество Forks, Watches и Commits. | Меньшее количество Forks, Watches и Commits. |
17 | Разработчики | Требуют опытных разработчиков и не так легко доступны для найма. | Большинство разработчиков менее опытны и встречаются в достаточном количестве. |
Flask против Node
Что касается стека веб-разработки, то оказывается, что разработка для Интернета требует объединения различных технологий. Мы должны разделить веб-приложение на фронтенд и бэкенд. Фронтенд лучше всего разрабатывать на технологиях, которые работают в браузере, таких как JavaScript, HTML и CSS.
Как правило, бэкэнд разрабатывается на языках, которые подходят для серверной стороны и могут взаимодействовать с базовой операционной системой, подключенными базами данных или сетью, когда это необходимо.
Однако фреймворк на основе JavaScript под названием NodeJS изменил эту точку зрения и позволил разработчикам добиться последовательности и единообразия в разработке фронтэнда и бэкэнда веб-приложений. Разработчики могли разрабатывать для бэкэнда, используя JavaScript.
В этом разделе "Flask vs Node" мы сравним Flask, который является фреймворком на основе языка программирования Python, с Node, который основан на среде выполнения JavaScript в Chrome, по различным критериям, таким как архитектура, скорость, поддержка сообщества и т.д.
# | Критерии | Фляга | Узел |
---|---|---|---|
1 | Время выполнения языка | Python | Движок V8 JavaScript в Chrome |
2 | Архитектура | Неблокирующий ввод-вывод требует использования неблокирующих веб-серверов, таких как gunicorn. Категория Микрофреймворк (back end). | По своей сути обеспечивает неблокируемый ввод-вывод. Категория Fullstack |
3 | Менеджер по работе с пакетами | pip | npm |
4 | Скорость | Медленнее из-за отдельного интерпретатора Python. | Быстрее благодаря компилятору Just-In-Time. |
5 | Открытый источник | Да | Да |
6 | Поддержка сообщества | На Github 2.3 K Часы 51.4 K Звезды 13.7 K Вилы | На Github 2.9 K Часы 71.9 K Звезды 17.6 K Вилы |
7 | Отладка | Легче отлаживать с помощью отладчика Python без зависимостей. | Требует больше усилий. Проще с IDE для разработки с библиотекой Bluebird / Promise. |
8 | Техническое обслуживание | Не требует особого ухода | Более высокое содержание |
9 | Приложения реального времени | По своей сути не подходит. Однако может работать вместе с socket.io для случаев использования в реальном времени. Используйте расширение Flask-socketio. | Подходит благодаря событийно-ориентированной архитектуре и потоковым модулям. По своей сути асинхронна. |
10 | Библиотеки | Более зрелый и стабильный. | Менее зрелый и стабильный, но в рамках активной разработки и выпуска исправлений. |
11 | Качество кода | Он создан исключительно для задней части. | Иногда это нарушается из-за того, что новые разработчики фронтенда переходят на бэкенд. |
12 | Состав команды разработчиков | Команды обычно состоят из Back end разработчиков и front end разработчиков. Концерны разделены. | Разработчики могут обмениваться ролями и работать как на фронт-энд, так и на бэк-энд. |
13 | Интеграция с существующей системой и приложениями | Более простая интеграция с другими существующими бэкенд-приложениями с использованием экосистемы Python для приложений машинного обучения и больших данных. | Достаточно новый и требует создания пользовательских или новых библиотек для интеграции с другими существующими приложениями. |
Часто задаваемые вопросы
Q #1) Что мне следует изучать в первую очередь, Django или Flask?
Ответ: Сначала лучше выбрать Flask. Когда вы приобретете небольшой опыт в веб-разработке, вы можете заняться Django. Django предполагает, что вы уже знаете, как работают веб-приложения, и он сам позаботится о большей части функциональности.
Вопрос #2) Что лучше - Flask или Django?
Ответ: И Flask, и Django превосходны и соответствуют своему назначению. Django используется для создания более выдающихся приложений корпоративного масштаба. Flask используется для создания статичных и небольших приложений. Flask также подходит для создания прототипов. Однако, используя расширения Flask, мы можем создавать и большие приложения.
Q #3) Какие компании используют Flask?
Ответ: Среди компаний, использующих Flask, - Reddit, Mailgun, Netflix, Airbnb и др.
Вопрос # 4) Какие сайты используют Django?
Ответ: Некоторые из сайтов, использующих Django, - это Instagram, Spotify, YouTube, Dropbox, Bitbucket, Eventbrite и др.
Заключение
Мы не должны надолго зацикливаться на одном фреймворке. Мы должны быть готовы осваивать новые наборы технологий и внедрять самые современные стеки. Некоторые из нас хотят сравнительно "из коробки", с батарейным питанием, с жесткими циклами выпуска, с поддержанием жесткой обратной совместимости и т.д.
Если вы считаете, что больше относитесь к этой группе, то вам следует выбрать Django. Однако и фреймворк Flask может порадовать новыми возможностями и гибкостью. Если вы хотите поддерживать согласованность между фронт-эндом и бэк-эндом, вы можете выбрать фреймворк полного стека, например, NodeJS.
Выбор фреймворка - это скорее выбор, который зависит от контекста и проблем, которые мы пытаемся решить. Выбор фреймворка всегда труден. Мы надеемся, что в этом руководстве мы представили основные моменты обзора, и это поможет вам окончательно выбрать один фреймворк. Однако мы рекомендуем изучить оба фреймворка.
Проще начать с Flask, а затем перейти к Django после приобретения некоторого опыта в веб-разработке. Если по каким-то причинам ваши усилия по разработке требуют использования JavaScript, вы можете перейти к NodeJS.