Flask i Django to oparte na Pythonie frameworki do tworzenia stron internetowych. Ten samouczek szczegółowo porównuje Django i Flask. Pokrótce omówiono także Flask i Node:
Wybór frameworka do kolejnego projektu zawsze stanowił dylemat. Co kilka miesięcy pojawia się nowa technologia i framework, który przezwycięża słabości poprzedniego, z którego korzystałeś.
Framework jest bardziej jak cicha kultura i zestaw konwencji, których należy przestrzegać, aby być bardziej istotnym i produktywnym w tym ciągle zmieniającym się świecie technologii. Porównywalnie, rozwój sieci porusza się znacznie szybciej niż rozwój komputerów stacjonarnych.
Django vs Flask
W tym samouczku szczegółowo porównamy Django i Flask. Flask i Django to frameworki do tworzenia stron internetowych oparte na Pythonie. Wiele z nich zmierza w kierunku lekkich mikroframeworków. Te frameworki są zwinne, elastyczne, małe i pomagają w tworzeniu mikrousług i aplikacji bezserwerowych.
Biorąc pod uwagę popularność NodeJS, w sekcji Flask vs. Node zamieściliśmy również porównanie Flask i Node. Ocena Django i Flask pod kątem następujących cech pomoże ci wybrać jedną z nich.
Domyślny administrator
Oba frameworki zapewniają bootstrapowaną aplikację administracyjną. W Django jest ona wbudowana i dostarczana wraz z domyślną instalacją. Jednak w przypadku Flask, aby mieć interfejs administratora, musisz zainstalować Flask-Appbuilder.
W międzyczasie pamiętaj o utworzeniu superużytkownika w Django i administratora w przypadku Flaska, abyś mógł zalogować się do zaplecza administracyjnego za pomocą przeglądarki.
Bazy danych i ORMS
Django jest dostarczane z domyślnie wbudowanym ORM, który wspiera interakcję z RDBMS takimi jak Oracle, MySQL, PostgreSQL, SQLite, itp. Ten ORM wspiera także generowanie i zarządzanie migracjami. Tworzenie modeli baz danych z wbudowanymi walidacjami jest stosunkowo wygodniejsze.
Flask również nie narzuca żadnej konkretnej metody i jest dostępny do użycia z różnymi rozszerzeniami, które obsługują podobne funkcje, jak opisano w przypadku Django. Podaliśmy przykłady Flask-SQLAlchemy, Flask-Migrate, Flask-MongoEngine, w jednym z tutoriali z tej serii.
Widoki i trasy
Oba frameworki mają mechanizmy deklarowania widoków opartych na metodach i klasach. W przypadku Django, trasy i widoki są wymienione w osobnych plikach. Ponadto, zawsze musimy jawnie przekazać obiekt żądania.
Z drugiej strony, we Flasku możemy użyć dekoratora, aby wspomnieć o trasach dla odpowiednich handlerów. Obiekt żądania we Flasku jest globalny i jest po prostu dostępny bez żadnego wyraźnego przekazywania. Szczegółowo opisaliśmy koncepcje korzystania z widoków i tras w jednym z naszych tutoriali.
Formularze i szablony
Formularze Django są wbudowane we framework i nie wymagają instalacji. Formularze są dość istotne dla aplikacji, a w Django mogą być przekazywane do tagów szablonów i są dostępne do renderowania w szablonach. Jednak w przypadku Flaska, musimy użyć Flask-WTF.
Do tworzenia formularzy wykorzystaliśmy również Flask-Appbuilder, a także WTF-Alembic do generowania formularzy HTML na podstawie modeli bazodanowych.
Oba frameworki obsługują szablony Jinja2 i obsługują serwowanie plików statycznych z wbudowanymi funkcjami do generowania adresów URL zasobów i jest to dość powszechny wzorzec we wszystkich frameworkach w dzisiejszych czasach.
Chociaż istnieją różne sposoby przekazywania zmiennych i renderowania szablonów w ich konkretnych metodach widoku, oba frameworki mają tę samą składnię dostępu do zmiennych w szablonach.
Elastyczność
Django, ze względu na swój rozmiar i złożoność, jest mniej elastyczny niż Flask. Flask można łatwo rozszerzyć za pomocą ogromnej liczby rozszerzeń, które obsługuje. Dlatego konfiguracja Flaska wymaga więcej czasu i wysiłku, ponieważ musimy ocenić więcej rozszerzeń.
Swoboda dana programistom w pewien sposób skutkuje wolniejszym rozwojem i dostarczaniem. Z drugiej strony, Django podąża za zestawem już ustalonych konwencji i podąża za archetypami, które wymagają mniej odstępstw od celów i założeń projektu.
Krzywa uczenia się
Nauka zarówno Django, jak i Flaska zajmuje prawie tyle samo czasu. Flask ma mniejszy interfejs API; dlatego ludzie mogą być w stanie ukończyć go szybciej, jeśli chodzi o podstawowy framework. Staje się równie trudny, jeśli chodzi o korzystanie z jego rozszerzeń. Wkrótce może stać się uciążliwy.
Jednak tylko dlatego, że wszystko nie jest spakowane w jednym pakiecie, łatwiej jest praktykować separację obaw w przypadku frameworka Flask.
Zalecamy naukę wzorców, a nie składni, która jest stosowana. Zarówno Django, jak i Flask mają doskonałą dokumentację, którą można łatwo śledzić podczas tworzenia funkcji.
Rozmiar i czas trwania projektu
Jeśli pracujesz nad większym projektem z większymi zespołami, lepiej jest skorzystać z dojrzałości Django i szerokiego wsparcia kontrybutorów. Jeśli twój projekt jest mniejszy i wymaga mniejszej liczby programistów, lepiej jest wybrać Flask.
Co więcej, jeśli twój projekt ma trwać długo, to Django jest właściwym wyborem; w przeciwnym razie możesz wybrać Flask.
Typ aplikacji
Wcześniej Django był uważany za właściwy wybór, gdy istniało zapotrzebowanie na pełnoprawne aplikacje internetowe na skalę korporacyjną. Ale dziś Flask jest równie dojrzały i może dobrze służyć w tych samych warunkach.
Jednak programiści wybierają Flask bardziej do tworzenia małych lub statycznych stron internetowych lub podczas szybkiego wdrażania usług internetowych RESTful API.
Rekrutacja programistów
Posiadanie wykwalifikowanych zasobów w konwencji frameworka, którego używasz, opłaca się. Możesz spodziewać się szybszego rozwoju, szybszego testowania, szybszego dostarczania i szybszego rozwiązywania problemów.
W przypadku Flaska dość łatwo jest znaleźć nowych deweloperów. Jednak znalezienie wykwalifikowanych zasobów w Django jest wyzwaniem. Nie ma zbyt wielu gotowych do zatrudnienia deweloperów Django. Co więcej, framework Django jest dość stary, a zatem większość nowych pracowników jest droga w porównaniu do tych, którzy są wykwalifikowani we frameworku Flask.
Nowi absolwenci kierunków technicznych również wybierają lekkie frameworki, takie jak Flask, ponieważ trendy branżowe zmierzają w kierunku tworzenia aplikacji z oddzielonymi mikrousługami lub technologią wspierającą tworzenie implementacji bezserwerowych. Javascript jest szeroko stosowany wraz z frameworkami, które są łatwiejsze w użyciu i bardziej popularne.
Open Source
Zarówno Flask, jak i Django są projektami open-source. Django można znaleźć pod adresem //github.com/django/django, a Flask pod adresem //github.com/pallets/flask. Patrząc na te projekty, liczba współtwórców Django jest znacznie większa niż liczba współtwórców Flaska.
W związku z tym możemy oczekiwać większego i szybszego wsparcia, jeśli mamy jakieś problemy i zapytania, które wymagają rozwiązania. W przeciwieństwie do typowych założeń, liczba użytkowników projektu Flask jest wyższa niż w przypadku Django.
Jednym z niepokojących faktów dotyczących Flask jest to, że może nie istnieć stabilne rozszerzenie dla konkretnego zadania. Dlatego też praca polegająca na odfiltrowaniu najlepszego z nich pozostaje w gestii użytkownika rozszerzenia.
Na przykład, W ostatnim samouczku użyliśmy Flask-Twitter-oembedder do pracy z API Twittera, ale to rozszerzenie miało pewne problemy, z powodu których musieliśmy przełączyć się z Flask-Cache na Flask-Caching.
Musieliśmy nawet dołączyć niestandardową instrukcję instalacji, aby zainstalować Flask-twitter-oembedder z naszego zaktualizowanego repozytorium Github, zamiast wspominać o nim w naszym pliku requrements.txt projektu.
Częsta konserwacja jest typowym wyzwaniem, z którym będziesz musiał się zmierzyć w przypadku projektu open-source. Wsparcie i zarządzanie projektem open-source są zwykle powiązane z płatnymi usługami. Być może będziesz musiał długo czekać, aby uzyskać kilka poprawek od współtwórców projektu.
Wydajność
Framework Flask jest lżejszy niż Django i działa lepiej z pomijalnymi różnicami, szczególnie biorąc pod uwagę operacje I/O.
Spójrz na poniższe porównania. Wraz ze wzrostem liczby żądań, wydajność Flaska pozostaje prawie taka sama. Jednak Django zajmuje więcej czasu na renderowanie szablonów po pobraniu danych za pomocą ORM.
Python Flask vs Django: tabelaryczne porównanie
# | Cechy | Django | Kolba |
---|---|---|---|
1 | Domyślny administrator | Wbudowane zaplecze administracyjne | Zainstaluj Flask-Appbuilder |
2 | Włącz domyślnego administratora | W pliku settings.py należy odkomentować zainstalowaną przez administratora aplikację. ... # Definicja aplikacji INSTALLED_APPS = [ 'strona internetowa', 'django.contrib.admin', # inny kod ] ... | Zaimportuj AppBuilder i SQLA z flask_appbuilder, najpierw zainicjuj DB, a następnie Appbuilder. from flask import Flask from flask_appbuilder import AppBuilder, SQLA app=Flask(__name__) db = SQLA(app)appbuilder=AppBuilder(app, db.session) |
3 | Utwórz użytkownika administratora | python manage.py createsuperuser | flask fab create-admin |
4 | Bazy danych i ORMS | Wbudowany ORM dla RDBMS Używaj Django-nonrel dla backendów NoSQL | Zainstaluj Flask-SQLAlchemy Rozszerzenie Flask specyficzne dla NoSQL, takie jak Flask-MongoEngine |
5 | Widoki i trasy | URLConf w urls.py from django.urls import path z .import views urlpatterns = [ path('/path', views.handler_method), # inne adresy URL i programy obsługi ] | Użyj dekoratora @app.route("/path") w widokach, aby zmapować trasę z funkcją. @app.route("/path") def handler_method(): # inny kod z dalszą logiką |
6 | Szablony renderowania | W widokach from django.shortcuts import render def example_view(request): tempvar="value_for_template" return render( żądanie, 'demo.html', {"tempvar":tempvar} ) | W widokach from . import app from flask import request from flask import render_template @app.route("/path") def demo(): tempvar="value_for_template" return render_template( "demo.html", temp_var=temp_var ) |
7 | Zmienna interpolacja w szablonach | W templates/demo.html {{ tempvar }} | W templates/demo.html {{ tempvar }} |
8 | Elastyczność | Mniej elastyczny | Większa elastyczność |
9 | Decyzje projektowe | Mniej decyzji projektowych z deweloperami. | Więcej swobody dla deweloperów. |
10 | Odchylenie projektu | Mniejsze odchylenia od celów projektu. | Więcej odchyleń ze względu na swobodę daną deweloperom. |
11 | Rozmiar bazy kodu | Większa baza kodu | Mniejsza baza kodu |
12 | Liczba interfejsów API | Więcej interfejsów API | Mniej interfejsów API |
13 | Typ aplikacji | Pełnoprawne aplikacje internetowe | Mniejsze aplikacje / mikrousługi |
14 | Aplikacje RESTful | Django REST framework dla aplikacji RESTful. | Użyj następujących rozszerzeń dla aplikacji RESTful. Flask-RESTful Flask-RESTX Połączenie |
15 | Wydajność | Niska wydajność przy dużej liczbie żądań. | Stała wydajność przez cały czas. |
16 | Wkład Open Source | Większa liczba Forków, Watchy i Commitów. | Mniejsza liczba rozwidleń, obserwacji i zatwierdzeń. |
17 | Deweloperzy | Wymaga doświadczonych programistów, którzy nie są łatwo dostępni w procesie rekrutacji. | Większość deweloperów jest mniej doświadczona i występuje w odpowiedniej liczbie. |
Flask vs Node
W odniesieniu do stosu programistycznego okazuje się, że tworzenie aplikacji internetowych wymaga połączenia różnych technologii. Musimy podzielić aplikację internetową na frontend i backend. Front-endową część aplikacji najlepiej opracować w technologiach uruchamianych w przeglądarce, takich jak JavaScript, HTML i CSS.
Ogólnie rzecz biorąc, backend jest opracowywany w językach odpowiednich dla strony serwera i może wchodzić w interakcje z bazowym systemem operacyjnym, połączonymi bazami danych lub siecią, gdy jest to wymagane.
Jednak framework oparty na JavaScript o nazwie NodeJS zmienił powyższy pogląd i umożliwił programistom spójność i jednolitość w zakresie rozwoju front-end i back-end dla aplikacji internetowych. Deweloperzy mogli rozwijać back-end za pomocą JavaScript.
W tej sekcji Flask vs Node porównujemy Flask, który jest frameworkiem opartym na języku programowania Python, z Node, który jest oparty na środowisku uruchomieniowym JavaScript Chrome pod względem różnych kryteriów, takich jak architektura, szybkość, wsparcie społeczności itp.
# | Kryteria | Kolba | Węzeł |
---|---|---|---|
1 | Language Runtime | Python | Silnik JavaScript V8 w Chrome |
2 | Architektura | Nieblokujące wejścia/wyjścia wymagają użycia nieblokujących serwerów internetowych, takich jak gunicorn. Kategoria Microframework (back-end). | Nieodłącznie zapewnia nieblokujące wejścia/wyjścia. Kategoria Fullstack |
3 | Menedżer pakietów | pip | npm |
4 | Prędkość | Wolniejsza z powodu oddzielnego interpretera Pythona. | Szybciej dzięki kompilatorowi Just-In-Time. |
5 | Otwarte źródło | Tak | Tak |
6 | Wsparcie społeczności | Na Github 2.3 K Watches 51.4 K Stars 13.7 K Forks | Na Github 2.9 K Zegarki 71.9 K Stars 17.6 K Forks |
7 | Debugowanie | Łatwiejsze debugowanie dzięki debuggerowi Python bez zależności. | Wymaga więcej wysiłku. Łatwiej z IDE programistycznym z biblioteką Bluebird / Promise. |
8 | Konserwacja | Niskie koszty utrzymania | Wyższa konserwacja |
9 | Aplikacje działające w czasie rzeczywistym | Z natury nie nadaje się, ale może współpracować z socket.io w przypadkach użycia w czasie rzeczywistym. Użyj rozszerzenia Flask-socketio. | Odpowiedni ze względu na architekturę sterowaną zdarzeniami i moduły strumieniowe. Z natury asynchroniczny. |
10 | Biblioteki | Bardziej dojrzały i stabilny. | Mniej dojrzała i stabilna, ale aktywnie rozwijana i wydawana z poprawkami. |
11 | Jakość kodu | Jest on tworzony wyłącznie dla zaplecza. | Czasami jest to zagrożone, ponieważ nowi programiści front-endu przechodzą na back-end. |
12 | Skład zespołu deweloperów | Zespoły składają się zazwyczaj z programistów back-end i front-end, a ich zadania są oddzielne. | Programiści mogą wymieniać się rolami i pracować zarówno dla front-endu, jak i back-endu. |
13 | Integracja z istniejącym systemem i aplikacjami | Łatwiejsza integracja z innymi istniejącymi aplikacjami backendowymi przy użyciu ekosystemu Python do uczenia maszynowego i aplikacji Big Data. | Jest to dość nowe rozwiązanie, które wymaga utworzenia niestandardowych lub nowych bibliotek w celu integracji z innymi istniejącymi aplikacjami. |
Często zadawane pytania
P #1) Czego powinienem nauczyć się najpierw, Django czy Flask?
Odpowiedź: Lepiej jest najpierw przejść na Flask, a gdy zdobędziesz trochę doświadczenia w tworzeniu stron internetowych, możesz zająć się Django. Django zakłada, że wiesz już, jak działają aplikacje internetowe i sam zajmuje się większością funkcji.
P #2) Czy lepszy jest Flask czy Django?
Odpowiedź: Zarówno Flask, jak i Django są doskonałe i nadają się do swoich celów. Django jest używany do tworzenia bardziej znanych aplikacji na skalę korporacyjną. Flask jest używany do tworzenia statycznych i mniejszych aplikacji. Flask nadaje się również do prototypowania. Jednak przy użyciu rozszerzeń Flask możemy również tworzyć duże aplikacje.
P #3) Jakie firmy korzystają z Flask?
Odpowiedź: Niektóre z firm korzystających z Flask to Reddit, Mailgun, Netflix, Airbnb itp.
P #4) Jakie strony używają Django?
Odpowiedź: Niektóre z witryn korzystających z Django to Instagram, Spotify, YouTube, Dropbox, Bitbucket, Eventbrite itp.
Wnioski
Nie powinniśmy fiksować się na jednym frameworku przez długi czas. Powinniśmy być gotowi do nauki nowych zestawów technologii i przyjmowania trendów. Niektórzy z nas chcą porównywalnie nieszablonowych podejść z bateriami i sztywnymi cyklami wydawniczymi, utrzymując ściślejszą kompatybilność wsteczną itp.
Jeśli uważasz, że należysz bardziej do tej grupy, to musisz wybrać Django. Jednak niesamowicie jest chodzić wraz z nowymi funkcjami i elastycznością frameworka Flask. Jeśli chcesz zachować spójność między front-endem a back-endem, możesz wybrać framework typu full-stack, taki jak NodeJS.
Wybór frameworka jest raczej wyborem, który zależy od kontekstu i problemów, które próbujemy rozwiązać. Wybór frameworka jest zawsze trudny. Mamy nadzieję, że przedstawiliśmy najważniejsze punkty przeglądu w tym samouczku i pomoże ci to w sfinalizowaniu jednego frameworka. Zalecamy jednak poznanie obu frameworków.
Łatwiej jest zacząć od Flask, a następnie przejść do Django po zdobyciu doświadczenia w tworzeniu stron internetowych. Jeśli z jakiegoś powodu twoje wysiłki programistyczne wymagają użycia JavaScript, możesz przejść do NodeJS.