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, който поддържа взаимодействие с RDBMS, като 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 се уверете, че сте разкоментирали инсталираното от администратора приложение. ... # Дефиниция на приложение INSTALLED_APPS = [ "уебсайт", 'django.contrib.admin', # друг код ] ... | Импортиране на AppBuilder и SQLA от flask_appbuilder, първо инициализирайте БД и след това Appbuilder от flask внос Flask от flask_appbuilder внос 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 за RDBMS Използване на Django-nonrel за NoSQL backends | Инсталиране на Flask-SQLAlchemy Специфично за NoSQL разширение на Flask, например Flask-MongoEngine |
5 | Изгледи и маршрути | URLConf в urls.py from django.urls import path от .import views urlpatterns = [ path('/path', views.handler_method), # други адреси и обработчици ] | Използвайте декоратора @app.route("/path") в изгледите, за да съпоставите маршрут с функция. @app.route("/path") def handler_method(): # друг код с допълнителна логика |
6 | Шаблони за визуализация | В мнения from django.shortcuts import render def example_view(request): tempvar="value_for_template" връщане на render( искане, 'demo.html', {'tempvar':tempvar} ) | В мнения от . внос на app от flask импортиране на заявка от flask внос render_template @app.route("/path") def demo(): tempvar="value_for_template" връщане на 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 за RESTful приложения. | Използвайте следните разширения за RESTful приложения. Flask-RESTful Flask-RESTX Свързване |
15 | Изпълнение | Бавна работа, когато броят на заявките е голям. | Последователно представяне през цялото време. |
16 | Принос към отворения код | По-голям брой разклонения, наблюдения и коммитвания. | По-малък брой разклонения, наблюдения и коммитвания. |
17 | Разработчици | Изискват опитни разработчици и не са лесно достъпни за набиране на персонал. | Повечето от разработчиците са с по-малък опит и се намират в достатъчен брой. |
Flask Vs Node
Що се отнася до стека за разработка на уеб приложения, оказва се, че разработването на уеб приложения изисква съчетаване на различни технологии. Трябва да разделим едно уеб приложение на frontend и backend. Front-end частта на приложението се разработва най-добре с технологиите, които се изпълняват в браузъра, като JavaScript, HTML и CSS.
Обикновено бекендът се разработва на езици, които са подходящи за сървърната част и могат да взаимодействат с основната операционна система, свързаните бази данни или мрежата, когато е необходимо.
Базираната на JavaScript рамка, наречена NodeJS, обаче промени горепосочената гледна точка и даде възможност на разработчиците да постигнат последователност и еднородност при разработката на уеб приложения от предната и задната част. Разработчиците можеха да разработват за задната част с помощта на JavaScript.
В този раздел Flask vs Node сравняваме Flask, която е базирана на езика за програмиране Python, с Node, която е базирана на JavaScript runtime на Chrome, по различни критерии, като архитектура, скорост, поддръжка от общността и др.
# | Критерии | Флакон | Възел |
---|---|---|---|
1 | Изпълнение на езика | Python | Двигателят V8 на JavaScript в Chrome |
2 | Архитектура | Неблокиращият вход/изход изисква използването на неблокиращи уеб сървъри, като например gunicorn. Категория Микрорамка (бек енд). | По своята същност осигурява неблокиращ вход/изход. Категория 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 Library. |
8 | Поддръжка | Ниска поддръжка | По-висока поддръжка |
9 | Приложения в реално време | По своята същност не е подходящ. Въпреки това може да работи заедно със socket.io за случаи на употреба в реално време. Използвайте разширението Flask-socketio. | Подходящ поради архитектурата, управлявана от събития, и поточните модули. По своята същност е асинхронен. |
10 | Библиотеки | По-зрели и стабилни. | По-малко зряла и стабилна, но в рамките на активна разработка и издаване на поправки. |
11 | Качество на кода | Създаден е изключително за задния край. | Понякога тя се компрометира поради преминаването на нови разработчици от предния край към задния. |
12 | Състав на екипа на разработчиците | Екипите обикновено се състоят от разработчици на бек енд и разработчици на фронт енд. Проблемите са отделни. | Разработчиците могат да разменят ролите си и да работят както за предната, така и за задната част. |
13 | Интеграция със съществуваща система и приложения | По-лесно интегриране с други съществуващи наследени бекенд приложения с помощта на екосистемата на Python за приложения за машинно обучение и големи данни. | Сравнително нова и изисква създаването на потребителски или нови библиотеки за интегриране с други съществуващи приложения. |
Често задавани въпроси
В #1) Какво трябва да науча първо - Django или Flask?
Отговор: По-добре е първо да се заемете с Flask. След като натрупате малко опит в уеб разработката, можете да се заемете с Django. Django предполага, че вече знаете как работят уеб приложенията, и сам се грижи за повечето от функционалностите.
В #2) Flask или Django е по-добър?
Отговор: Както Flask, така и Django са отлични и подходящи за своите цели. Django се използва за създаване на по-значими приложения от корпоративен мащаб. Flask се използва за създаване на статични и по-малки приложения. Flask е подходящ и за създаване на прототипи. С помощта на разширенията на Flask обаче можем да създаваме и големи приложения.
В #3) Кои компании използват Flask?
Отговор: Някои от компаниите, които използват Flask, са Reddit, Mailgun, Netflix, Airbnb и др.
Q #4) Кои сайтове използват Django?
Отговор: Някои от сайтовете, които използват Django, са Instagram, Spotify, YouTube, Dropbox, Bitbucket, Eventbrite и др.
Заключение
Не трябва да се фиксираме за дълго с една рамка. Трябва да сме готови да научим нови набори от технологии и да приемем тенденциите в стековете. Някои от нас искат сравнително готови подходи, включени в батериите, с твърди цикли на пускане, поддържащи по-тясна обратна съвместимост и т.н.
Ако смятате, че принадлежите по-скоро към тази група, тогава трябва да изберете Django. Въпреки това е невероятно да вървите заедно с новите функции и гъвкавостта на рамката Flask. Когато искате да поддържате съгласуваност между фронт енда и бекенда, можете да изберете full-stack рамка като NodeJS.
Изборът на рамка е по-скоро избор, който зависи от контекста и проблемите, които се опитваме да решим. Изборът на рамка винаги е труден. Надяваме се, че в този урок сме представили основните точки за преглед и това ще ви помогне при окончателното определяне на една рамка. Въпреки това препоръчваме да изучите и двете рамки.
По-лесно е да започнете с Flask и след това да преминете към Django, след като натрупате известен опит в уеб разработката. Ако по някаква причина усилията ви за разработка изискват използването на JavaScript, можете да продължите с NodeJS.