Flask i Django són marcs de desenvolupament web basats en Python. Aquest tutorial compara Django amb Flask en detall. Flask vs Node també es tracta breument:
Sempre ha estat un dilema generalitzat quan es tracta de seleccionar un marc per al vostre proper projecte. Cada pocs mesos, veus noves tecnologies i un marc que supera la debilitat de l'anterior que vas utilitzar.
Un framework s'assembla més a una cultura silenciosa, i un conjunt de convencions que has de seguir per ser més. rellevant i productiu en aquest món de la tecnologia en constant canvi. En comparació, el desenvolupament web es mou molt més ràpid que el desenvolupament d'escriptori.
Django Vs Flask
En aquest tutorial, fem una comparació entre Django i Flask en detall. Flask i Django són marcs de desenvolupament web basats en Python. Molts estan avançant cap a microframes lleugers. Aquests marcs són àgils, flexibles, petits i ajuden a desenvolupar microserveis i aplicacions sense servidor.
Tenint en compte la popularitat de NodeJS, també hem proporcionat una comparació prodigi entre Flask i Node a la secció Flask vs. Node. L'avaluació de Django i Flask de les funcions següents us ajudarà a seleccionar-ne una sobre l'altra.
Administrador predeterminat
Tots dos marcs proporcionen una aplicació d'administració arrancada. A Django, està integrat i ve amb el valor predeterminatva permetre als desenvolupadors tenir coherència i uniformitat en el desenvolupament frontal i posterior d'aplicacions web. Els desenvolupadors podrien desenvolupar per al back-end utilitzant JavaScript.
En aquesta secció Flask vs Node, comparem Flask, que és un marc basat en llenguatge de programació Python, amb Node, que es basa en el temps d'execució de JavaScript de Chrome en diversos criteris com ara com arquitectura, velocitat, suport de la comunitat, etc.
# | Criteris | Flask | Node |
---|---|---|---|
1 | Language Runtime | Python | Motor JavaScript V8 de Chrome |
2 | Arquitectura | E/S sense bloqueig requereix l'ús de servidors web que no bloquegen, com ara gunicorn. Categoria de microframework (back end). | Inherentment Proporciona E/S sense bloqueig. Categoria Fullstack |
3 | Gestor de paquets | pip | npm |
4 | Velocitat | Més lent a causa d'un intèrpret de Python separat. | Més ràpid gràcies al compilador Just-In-Time . |
5 | Codi obert | Sí | Sí |
6 | Suport de la comunitat | A Github 2,3K rellotges 51,4K estrelles 13,7K Forks | A Github 2,9 K rellotges 71,9 K estrelles 17,6 K Forks |
7 | Depuració | Més fàcil depurar amb el depurador de Python sense dependències. | Requereix més esforç. Més fàcil amb aIDE de desenvolupament amb Bluebird / Promise Library. |
8 | Manteniment | Baix manteniment | Major manteniment |
9 | Aplicacions en temps real | Inherentment no adequades. Tanmateix, pot funcionar juntament amb socket.io per a casos d'ús en temps real. Utilitzeu l'extensió Flask-socketio. | Adequat a causa de l'arquitectura basada en esdeveniments i els mòduls de streaming. Inherentment asíncrona. |
10 | Biblioteques | Més madures i estables. | Menys madures i estables però dins d'un desenvolupament actiu i correcte versions. |
11 | Qualitat del codi | Està creat exclusivament per al back-end. | De vegades es veu compromesa perquè els nous desenvolupadors de front-end canvien al backend. |
12 | Composició de l'equip de desenvolupadors | Equips solen estar composts per desenvolupadors de back-end i desenvolupadors de front-end. Les preocupacions estan separades. | Els desenvolupadors poden intercanviar rols i treballar tant per a front-end com per a back-end. |
13 | Integració amb el sistema i les aplicacions existents | Més fàcil d'integrar-se amb altres aplicacions de backend heretades utilitzant l'ecosistema de Python per a aplicacions d'aprenentatge automàtic i Big Data. | Bastant nou i requereix la creació de biblioteques personalitzades o noves per a la integració amb altres aplicacions existents. |
Preguntes freqüents
P #1) Què he de fer?aprèn primer, Django o Flask?
Resposta: És millor anar amb Flask primer. Quan tingueu una mica d'experiència en desenvolupament web, podeu utilitzar Django. Django suposa que ja saps com funcionen les aplicacions web i s'encarrega de la major part de la funcionalitat per si sol.
P #2) És millor Flask o Django?
Resposta: Tant Flask com Django són excel·lents i s'adapten al seu propòsit. Django s'utilitza per crear aplicacions a escala empresarial més destacades. Flask s'utilitza per crear aplicacions estàtiques i més petites. Flask també és adequat per a la creació de prototips. Tanmateix, amb l'ús de les extensions de Flask, també podem crear aplicacions grans.
P #3) Quines empreses utilitzen Flask?
Resposta: Algunes de les empreses que utilitzen Flask són Reddit, Mailgun, Netflix, Airbnb, etc.
P #4) Quins llocs utilitzen Django?
Resposta : Alguns dels llocs que utilitzen Django són Instagram, Spotify, YouTube, Dropbox, Bitbucket, Eventbrite, etc.
Conclusió
En realitat no ens hem de fixar amb un marc durant molt de temps . Hauríem d'estar preparats per aprendre nous conjunts de tecnologia i adoptar les piles de tendències que hi ha. Alguns de nosaltres volem enfocaments comparativament fora de la caixa, amb bateria inclosa, amb cicles d'alliberament rígids, mantenir una compatibilitat més estreta, etc.
Si creieu que pertanyeu més a aquest grup, heu de triar Django. No obstant això, és increïbletambé per caminar amb les noves funcions i la flexibilitat del marc de Flask. Quan voleu mantenir la coherència entre el front end i el backend, podeu triar un marc de pila completa com NodeJS.
Anar amb un marc és més una opció que depèn del context i dels problemes que intentem. resoldre. Seleccionar un marc sempre és difícil. Esperem haver presentat els punts de revisió essencials en aquest tutorial i us ajudarà a finalitzar un marc. Tanmateix, recomanem aprendre ambdós marcs.
És més fàcil començar amb Flask i després passar a Django després d'haver adquirit una mica d'experiència en desenvolupament web. Si per algun motiu els vostres esforços de desenvolupament requereixen l'ús de JavaScript, podeu continuar amb NodeJS.
instal·lació. Tanmateix, en el cas de Flask, cal instal·lar Flask-Appbuilder per tenir una interfície d'administració.Mentrestant, recordeu crear un superusuari a Django i un administrador en el cas de Flask perquè pugueu iniciar sessió al backend de l'administrador mitjançant el navegador.
Bases de dades i ORMS
Django s'envia amb un ORM integrat per defecte que admet totalment la interacció amb RDBMS com ara Oracle, MySQL, PostgreSQL, SQLite, etc. Aquest ORM també dóna suport a la generació i gestió de les migracions. És relativament més còmode crear models de bases de dades amb validacions incorporades.
Flask tampoc imposa cap mètode en particular i està disponible per utilitzar-se amb diverses extensions que admeten funcions similars com s'indica en el cas de Django. Hem donat exemples de Flask-SQLAlchemy, Flask-Migrate, Flask-MongoEngine, en un dels tutorials de la sèrie.
Views And Routes
Tots dos frameworks tenen mecanismes per declarar basats en mètodes i vistes basades en classe. En el cas de Django, les rutes i les vistes s'esmenten en fitxers separats. A més, sempre hem de passar l'objecte de sol·licitud de manera explícita.
D'altra banda, a Flask, podem utilitzar un decorador per esmentar les rutes dels controladors corresponents. L'objecte de sol·licitud a Flask és global i només està disponible sense cap transmissió explícita. Hem detallat els conceptes d'ús de vistes i rutes en un dels nostrestutorials.
Formes i plantilles
Els formularis de Django estan integrats al marc i no requereixen instal·lació. Els formularis són força essencials per a les aplicacions i, a Django, els formularis es poden passar a etiquetes de plantilla i estan disponibles per representar-los en plantilles. Tanmateix, en el cas de Flask, hem d'utilitzar Flask-WTF.
També hem fet ús de Flask-Appbuilder per crear formularis. A més, WTF-Alembic es pot utilitzar per generar formularis HTML basats en models de bases de dades.
Ambdós marcs admeten plantilles Jinja2 i tots dos admeten el servei de fitxers estàtics amb funcions incorporades per generar els URL dels recursos i és un patró força comú a tots els frameworks d'avui en dia.
Tot i que hi ha diferents maneres de passar les variables i de representar les plantilles en els seus mètodes de visualització particulars, ambdós frameworks tenen la mateixa sintaxi d'accés a variables a les plantilles.
Flexibilitat
Django, per la seva gran mida i complexitat, és menys flexible que Flask. Flask es pot estendre fàcilment amb l'ajuda d'un gran nombre d'extensions que admet. Per tant, cal més temps i esforç per configurar Flask perquè hem d'avaluar més extensions.
La llibertat que es donen als desenvolupadors d'alguna manera fa que el desenvolupament i el lliurament siguin més lent. D'altra banda, Django segueix un conjunt de convencions ja establertes i segueix els arquetips que requereixen menys desviació.a partir dels objectius i metes del projecte.
Corba d'aprenentatge
Es requereix gairebé la mateixa quantitat de temps per aprendre tant Django com Flask. Flask té una API més petita; per tant, la gent podria acabar-lo més ràpid pel que fa al marc bàsic. Es torna igualment difícil quan es tracta d'utilitzar les seves extensions. Pot ser que aviat esdevingui feixuc.
No obstant això, només perquè no està tot en un sol paquet, és més fàcil practicar la separació de preocupacions en el cas del marc de Flask.
Us recomanem que aprendre els patrons i no la sintaxi que se segueix. Tant Django com Flask tenen una documentació excel·lent. Podeu seguir-lo fàcilment mentre desenvolupeu una funció.
Mida i durada del projecte
Quan treballeu en un projecte més gran amb equips més grans, és millor aprofitar la maduresa de Django i l'ampli suport de col·laboradors que té. Si el vostre projecte és més petit i requereix un nombre menor de desenvolupadors, és millor anar amb Flask.
A més, si el vostre projecte durarà molt de temps, llavors Django és l'opció correcta; en cas contrari, podeu seleccionar Flask.
Tipus d'aplicació
Anteriorment, Django es considerava l'opció correcta quan hi havia un requisit per a aplicacions web a escala empresarial de ple dret. Però, avui en dia, Flask és igual de madur i pot servir bé per a les mateixes condicions.
No obstant això, els desenvolupadors tendeixen atrieu més Flask per desenvolupar llocs web petits o estàtics, o mentre implementeu serveis web d'API RESTful per oferir ràpidament.
Reclutament de desenvolupadors
Tenir recursos especialitzats en la convenció del marc que utilitzeu val la pena. Podeu esperar un desenvolupament més ràpid, proves més ràpides, lliurament més ràpid i solucions de problemes més ràpides.
És bastant fàcil trobar desenvolupadors nous en el cas de Flask. Tanmateix, és difícil trobar recursos qualificats a Django. No n'hi ha molts preparats per ser contractats pels desenvolupadors de Django. A més, el marc de Django és bastant antic i, per tant, la majoria de les noves contractacions són cars de contractar en comparació amb els que tenen experiència en el marc de Flask.
Els nous graduats tècnics també estan agafant marcs lleugers com ara com Flask perquè les tendències del sector són la creació d'aplicacions amb microserveis desacoblats o la tecnologia que admet la creació de la implementació sense servidor. Javascript s'utilitza àmpliament juntament amb els frameworks que són més fàcils d'utilitzar i més populars.
Open Source
Tant Flask com Django són projectes de codi obert. Podeu trobar Django a //github.com/django/django i Flask a //github.com/pallets/flask. Tenint en compte aquests projectes, el nombre de col·laboradors a Django és força més gran que els que contribueixen a Flask.
Per tant, podem esperar més suport i més ràpid si tenim algunqüestions i consultes que necessiten resoldre. Contràriament a les suposicions habituals, el nombre d'usuaris del projecte Flask és superior al de Django.
Un fet preocupant sobre Flask és que pot ser que no hi hagi una extensió estable per a una tasca concreta. Per tant, la feina de filtrar la millor és l'usuari de l'extensió.
Per exemple, vam utilitzar Flask-Twitter-oembedder per treballar amb l'API de Twitter a l'últim tutorial, però aquesta extensió va tenir alguns problemes pels quals vam haver de canviar de Flask-Cache a Flask-Caching.
Fins i tot vam haver d'incloure una declaració d'instal·lació personalitzada per instal·lar Flask-twitter-oembedder des del nostre repositori de Github actualitzat en lloc de més que esmentar-ho al nostre fitxer requrements.txt del projecte.
El manteniment freqüent és un repte típic al qual s'enfrontarà amb un projecte de codi obert. El suport i la gestió del projecte de codi obert solen estar vinculats a serveis de pagament. Potser haureu d'esperar molt de temps per solucionar alguns problemes dels col·laboradors del projecte.
Rendiment
El marc Flask és més lleuger que Django i funciona millor amb diferències insignificants, especialment mentre tens en compte les operacions d'E/S.
Fes una ullada a les comparacions que es donen a continuació. Amb l'augment de les sol·licituds, el rendiment de Flask es manté gairebé igual. No obstant això, Django triga més temps a representar les plantilles després d'obtenir dades amb elORM.
Python Flask vs Django: una comparació tabular
# | Característiques | Django | Flask |
---|---|---|---|
1 | Administrador predeterminat | Builtin Admin Backend | Instal·la Flask -Appbuilder |
2 | Activa l'administrador predeterminat | A settings.py, assegureu-vos que no feu comentaris a l'aplicació instal·lada per l'administrador. ... # Definició d'aplicació INSTALLED_APPS = [ 'website', 'django.contrib.admin', # other codi ] ... | Importeu AppBuilder i SQLA des de flask_appbuilder, inicialitzeu primer la base de dades i després Appbuilder des de flask import Flask des de flask_appbuilder import AppBuilder, SQLA app=Flask(__name__) db = SQLA(app)appbuilder=AppBuilder(aplicació, db.session) |
3 | Crea un usuari administrador | python manage.py createsuperuser | flask fab create-admin |
4 | Bases de dades i ORMS | ORM integrat per a RDBMS Utilitzeu Django-nonrel per a backends NoSQL | Instal·leu Flask-SQLAlchemy A NoSQL Extensió específica de Flask, com ara Flask-MongoEngine |
5 | Vistes i rutes | URLConf a urls.py de django camí d'importació .urls des de .import views urlpatterns = [ path('/path', views.handler_method), # altres URL i gestors ] | Utilitzeu el decorador @app.route(“/path”) a les vistes per mapejar una ruta amb unfunction. @app.route(“/path”) def handler_method(): # altre codi amb més lògica |
6 | Plantilles de renderització | A les vistes des de django.shortcuts import render def example_view(request): tempvar=" value_for_template” retorn el render ( sol·licitud, 'demo.html', {'tempvar':tempvar} ) | En visualitzacions des de . importa l'aplicació des de la sol·licitud d'importació del flask des del flask import render_template @app.route(“/path”) def demo(): tempvar=”value_for_template” retorn render_template( “demo.html”, temp_var=temp_var ) |
7 | Interpolació de variables en plantilles | A templates/demo.html {{ tempvar }} | A templates/demo.html {{ tempvar }} |
8 | Flexibilitat | Menys flexible | Més flexible |
9 | Decisions de disseny | Menys decisions de disseny amb els desenvolupadors. | Més llibertat per als desenvolupadors. |
10 | Desviació del projecte | Menys desviació dels objectius del projecte. | Més desviació a causa de la llibertat concedida als desenvolupadors. |
11 | Mida de la base de codi | Base de codi més gran | Base de codi més petita |
12 | Nombre d'API | Més API | Menys API |
13 | Tipus d'aplicació | Aplicacions web completes | Aplicacions més petites /Microserveis |
14 | Aplicacions RESTful | Marc de Django REST per a aplicacions RESTful. | Utilitzeu les extensions següents per a aplicacions RESTful. Flask-RESTful Flask-RESTX Connexió |
15 | Rendiment | Rendiment lent quan el nombre de sol·licituds és gran. | Rendiment coherent a tot arreu. |
16 | Contribucions de codi obert | Més nombre de Forks, Watches i Commits. | Menor nombre de Forks, Watches i Commits. |
17 | Desenvolupadors | Requereix desenvolupadors experimentats i no estan disponibles fàcilment per a la contractació. | La majoria dels desenvolupadors tenen menys experiència i es troben en nombre adequat. |
Flask Vs Node
Respecte a la pila de desenvolupament web, resulta que el desenvolupament per a la web requereix una amalgama de diverses tecnologies. Hem de descompondre una aplicació web en un front-end i un backend. La part frontal de l'aplicació es desenvolupa millor amb les tecnologies que s'executen al navegador, com ara JavaScript, HTML i CSS.
En general, el backend es desenvolupa en idiomes adequats per al servidor. i pot interactuar amb el sistema operatiu subjacent, les bases de dades connectades o la xarxa quan sigui necessari.
No obstant això, un marc basat en JavaScript anomenat NodeJS va canviar la vista anterior i