Flask e Django sono framework di sviluppo web basati su Python. Questo tutorial mette a confronto Django e Flask in modo dettagliato, oltre a trattare brevemente Flask e Node:
La scelta di un framework per il vostro prossimo progetto è sempre stata un dilemma molto diffuso: ogni pochi mesi si presenta una nuova tecnologia e un framework che supera i punti deboli di quello precedente.
Un framework è più che altro una cultura silenziosa e un insieme di convenzioni da seguire per essere più rilevanti e produttivi in questo mondo tecnologico in continua evoluzione. In confronto, lo sviluppo Web si muove molto più velocemente dello sviluppo Desktop.
Django Vs Flask
In questo tutorial, illustriamo in dettaglio il confronto tra Django e Flask. Flask e Django sono framework di sviluppo web basati su Python. Molti si stanno orientando verso microframework leggeri, agili, flessibili, piccoli e che aiutano a sviluppare microservizi e applicazioni serverless.
Considerando la popolarità di NodeJS, abbiamo anche fornito un confronto prodigioso tra Flask e Node nella sezione Flask vs. Node. Valutare Django e Flask in base alle seguenti caratteristiche vi aiuterà a scegliere uno rispetto all'altro.
Admin predefinito
Entrambi i framework forniscono un'applicazione di amministrazione avviata. In Django, è integrata e viene fornita con l'installazione predefinita. Tuttavia, nel caso di Flask, è necessario installare Flask-Appbuilder per avere un'interfaccia di amministrazione.
Nel frattempo, ricordate di creare un superutente in Django e un admin nel caso di Flask, in modo da poter accedere al backend di amministrazione usando il browser.
Basi di dati e ORMS
Django viene fornito con un ORM predefinito che supporta pienamente l'interazione con RDBMS come Oracle, MySQL, PostgreSQL, SQLite, ecc. Questo ORM supporta anche la generazione e la gestione delle migrazioni. È relativamente più comodo creare modelli di database con convalide incorporate.
Inoltre, Flask non impone un metodo particolare ed è disponibile per essere utilizzato con varie estensioni che supportano caratteristiche simili, come nel caso di Django. Abbiamo fornito esempi di Flask-SQLAlchemy, Flask-Migrate, Flask-MongoEngine, in uno dei tutorial della serie.
Viste e percorsi
Entrambi i framework hanno meccanismi per dichiarare viste basate su metodi e classi. Nel caso di Django, le rotte e le viste sono menzionate in file separati. Inoltre, dobbiamo sempre passare esplicitamente l'oggetto richiesta.
D'altra parte, in Flask, possiamo usare un decoratore per menzionare le rotte per i gestori corrispondenti. L'oggetto request in Flask è globale ed è semplicemente disponibile senza alcun passaggio esplicito. Abbiamo dettagliato i concetti di utilizzo delle viste e delle rotte in uno dei nostri tutorial.
Moduli e modelli
I moduli di Django sono integrati nel framework e non richiedono installazione. I moduli sono essenziali per le applicazioni e in Django possono essere passati ai tag dei template e possono essere resi nei template. Tuttavia, nel caso di Flask, dobbiamo usare Flask-WTF.
Abbiamo anche utilizzato Flask-Appbuilder per creare i moduli e WTF-Alembic per generare moduli HTML basati su modelli di database.
Entrambi i framework supportano il templating di Jinja2 ed entrambi supportano il servizio di file statici con funzioni incorporate per generare gli URL delle risorse.
Sebbene esistano diversi modi per passare le variabili e per rendere i modelli nei loro particolari metodi di visualizzazione, entrambi i framework hanno la stessa sintassi per accedere alle variabili nei modelli.
Flessibilità
Django, a causa delle sue dimensioni e della sua complessità, è meno flessibile di Flask. Flask può essere facilmente esteso con l'aiuto di un vasto numero di estensioni che supporta. Pertanto, la configurazione di Flask richiede più tempo e sforzi perché dobbiamo valutare più estensioni.
La libertà concessa agli sviluppatori, in un certo senso, si traduce in uno sviluppo e in una consegna più lenti. D'altra parte, Django segue un insieme di convenzioni già stabilite e segue gli archetipi che richiedono una minore deviazione dagli obiettivi e dalle finalità del progetto.
Curva di apprendimento
L'apprendimento di Django e Flask richiede quasi la stessa quantità di tempo. Flask ha un'API più piccola; pertanto, le persone potrebbero essere in grado di completarlo più velocemente per quanto riguarda il framework principale. Diventa ugualmente impegnativo quando si tratta di utilizzare le sue estensioni. Potrebbe diventare presto ingombrante.
Tuttavia, proprio perché non tutto è racchiuso in un unico pacchetto, è più facile praticare la separazione delle preoccupazioni nel caso del framework Flask.
Si consiglia di imparare gli schemi e non la sintassi che si segue. Sia Django che Flask hanno una documentazione eccellente, che si può seguire facilmente durante lo sviluppo di una funzione.
Dimensione e durata del progetto
Quando si lavora a un progetto più grande con team più numerosi, è meglio approfittare della maturità di Django e dell'ampio supporto dei collaboratori. Se il progetto è più piccolo e richiede un numero minore di sviluppatori, è meglio scegliere Flask.
Inoltre, se il vostro progetto è destinato a durare a lungo, Django è la scelta giusta; altrimenti, potete scegliere Flask.
Tipo di applicazione
In passato Django era considerato la scelta giusta quando c'era bisogno di applicazioni web complete su scala aziendale, ma oggi Flask è altrettanto maturo e può essere utile per le stesse condizioni.
Tuttavia, gli sviluppatori tendono a scegliere Flask più che altro per lo sviluppo di siti web statici o di piccole dimensioni, o per l'implementazione di servizi web API RESTful veloci da fornire.
Assunzione di sviluppatori
Avere risorse esperte nella convenzione del framework che si utilizza ripaga: ci si può aspettare uno sviluppo più rapido, test più veloci, consegne più rapide e una più rapida risoluzione dei problemi.
È abbastanza facile trovare nuovi sviluppatori nel caso di Flask, mentre è difficile trovare risorse qualificate in Django. Non ci sono molti sviluppatori Django pronti per essere assunti. Inoltre, il framework Django è piuttosto vecchio e quindi la maggior parte dei nuovi assunti sono costosi da assumere rispetto a quelli che sono esperti nel framework Flask.
Anche i nuovi laureati in discipline tecniche scelgono framework leggeri come Flask, perché la tendenza del settore è quella di creare applicazioni con microservizi disaccoppiati o con la tecnologia che supporta la creazione di implementazioni serverless. Javascript è ampiamente utilizzato insieme ai framework più facili da usare e più popolari.
Open Source
Sia Flask che Django sono progetti open-source: Django si trova all'indirizzo //github.com/django/django e Flask all'indirizzo //github.com/pallets/flask. Guardando a questi progetti, il numero di collaboratori di Django è molto più ampio di quello dei collaboratori di Flask.
Pertanto, possiamo aspettarci un supporto maggiore e più rapido se abbiamo problemi e domande che devono essere risolti. Contrariamente alle ipotesi tipiche, il numero di utenti del progetto Flask è superiore a quello di Django.
Un aspetto preoccupante di Flask è che potrebbe non esistere un'estensione stabile per un particolare compito. Pertanto, il lavoro di filtrare la migliore rimane a carico dell'utente dell'estensione.
Ad esempio, Nell'ultimo tutorial abbiamo usato Flask-Twitter-oembedder per lavorare con le API di Twitter, ma questa estensione aveva alcuni problemi a causa dei quali abbiamo dovuto passare da Flask-Cache a Flask-Caching.
Abbiamo persino dovuto includere una dichiarazione di installazione personalizzata per installare Flask-twitter-oembedder dal nostro repo Github aggiornato, invece di menzionarlo nel file requrements.txt del progetto.
La manutenzione frequente è una sfida tipica che dovrete affrontare con un progetto open-source. Il supporto e la gestione del progetto open-source sono solitamente legati a servizi a pagamento. Potreste dover aspettare a lungo per ottenere la risoluzione di alcuni problemi da parte dei collaboratori del progetto.
Prestazioni
Il framework Flask è più leggero di Django e offre prestazioni migliori con differenze trascurabili, soprattutto se si considerano le operazioni di I/O.
Date un'occhiata ai confronti riportati di seguito. Con l'aumento delle richieste, le prestazioni di Flask rimangono pressoché invariate, mentre Django impiega più tempo per il rendering dei template dopo aver recuperato i dati con l'ORM.
Python Flask Vs Django: un confronto tabellare
# | Caratteristiche | Django | Fiaschetta |
---|---|---|---|
1 | Admin predefinito | Backend amministrativo integrato | Installare Flask-Appbuilder |
2 | Abilita l'amministratore predefinito | In settings.py, assicurarsi di decommentare l'applicazione installata dall'amministratore. ... # Definizione dell'applicazione APPLICAZIONI INSTALLATE = [ 'sito web', 'django.contrib.admin', # altro codice ] ... | Importare AppBuilder e SQLA da flask_appbuilder, inizializzando prima il DB e poi Appbuilder. da flask import Flask da flask_appbuilder import AppBuilder, SQLA app=Flask(__name__) db = SQLA(app)appbuilder=AppBuilder(app, db.session) |
3 | Creare un utente amministratore | python manage.py createsuperuser | flask fab create-admin |
4 | Basi di dati e ORMS | ORM integrato per RDBMS Usare Django-nonrel per i backend NoSQL | Installare Flask-SQLAlchemy Un'estensione di Flask specifica per NoSQL come Flask-MongoEngine |
5 | Viste e percorsi | URLConf in urls.py da django.urls importa il percorso da .import views urlpatterns = [ path('/path', views.handler_method), # altri url e gestori ] | Utilizzare il decoratore @app.route("/path") sulle viste per mappare una rotta con una funzione. @app.route("/percorso") def handler_method(): # altro codice con ulteriore logica |
6 | Modelli di rendering | In visualizzazioni da django.shortcuts import render def example_view(request): tempvar="valore_per_template" restituire( richiesta, 'demo.html', {'tempvar':tempvar} ) | In visualizzazioni da . import app da flask import request da flask import render_template @app.route("/percorso") def demo(): tempvar="valore_per_template" restituire render_template( "demo.html", temp_var=temp_var ) |
7 | Interpolazione variabile nei modelli | In templates/demo.html {{ tempvar }} | In templates/demo.html {{ tempvar }} |
8 | Flessibilità | Meno flessibile | Più flessibile |
9 | Decisioni di progettazione | Meno decisioni di progettazione con gli sviluppatori. | Più libertà per gli sviluppatori. |
10 | Deviazione del progetto | Minore deviazione dagli obiettivi del progetto. | Maggiore deviazione grazie alla libertà concessa agli sviluppatori. |
11 | Dimensione della base di codice | Base di codice più ampia | Codebase più piccola |
12 | Numero di API | Altre API | Meno API |
13 | Tipo di applicazione | Applicazioni web complete | Applicazioni più piccole / Microservizi |
14 | Applicazioni RESTful | Django REST framework per applicazioni RESTful. | Utilizzare le seguenti estensioni per le applicazioni RESTful. Flask-RESTful Fiasco-RESTX Connessione |
15 | Prestazioni | Prestazioni lente quando il numero di richieste è elevato. | Prestazioni costanti per tutto il tempo. |
16 | Contributi open source | Maggior numero di Forks, Watches e Commits. | Minor numero di fork, watch e commit. |
17 | Sviluppatori | Richiedono sviluppatori esperti e non sono facilmente disponibili per il reclutamento. | La maggior parte degli sviluppatori è meno esperta e si trova in numero adeguato. |
Flask vs Node
Per quanto riguarda lo stack di sviluppo web, è emerso che lo sviluppo per il web richiede un'amalgama di varie tecnologie. Dobbiamo suddividere un'applicazione web in front-end e back-end. La parte front-end dell'applicazione è meglio sviluppata con le tecnologie che girano nel browser, come JavaScript, HTML e CSS.
In genere, il backend è sviluppato in linguaggi adatti al lato server e può interagire con il sistema operativo sottostante, con i database collegati o con la rete quando necessario.
Tuttavia, un framework basato su JavaScript, chiamato NodeJS, ha cambiato la visione di cui sopra e ha permesso agli sviluppatori di avere coerenza e uniformità nello sviluppo del front-end e del back-end per le applicazioni web. Gli sviluppatori potevano sviluppare per il back-end utilizzando JavaScript.
In questa sezione Flask vs Node, confrontiamo Flask, che è un framework basato sul linguaggio di programmazione Python, con Node, che si basa sul runtime JavaScript di Chrome, in base a vari criteri come l'architettura, la velocità, il supporto della comunità, ecc.
# | Criteri | Fiaschetta | Nodo |
---|---|---|---|
1 | Lingua Runtime | Pitone | Il motore JavaScript V8 di Chrome |
2 | Architettura | L'I/O non bloccante richiede l'uso di server web non bloccanti, come gunicorn. Categoria microframework (back end). | Fornisce intrinsecamente I/O non bloccante. Categoria Fullstack |
3 | Gestore di pacchetti | pip | npm |
4 | Velocità | Più lento a causa di un interprete Python separato. | Più veloce grazie al compilatore Just-In-Time. |
5 | Fonte aperta | Sì | Sì |
6 | Sostegno alla comunità | Su Github 2,3 Orologi K 51,4 K Stelle 13,7 K Forchette | Su Github 2,9 K Orologi 71,9 K Stelle 17,6 K Forchette |
7 | Debug | Debug più facile con il debugger Python senza dipendenze. | Richiede uno sforzo maggiore. È più facile con un IDE di sviluppo con Bluebird / Promise Library. |
8 | Manutenzione | Bassa manutenzione | Manutenzione superiore |
9 | Applicazioni in tempo reale | Non è intrinsecamente adatto, ma può funzionare insieme a socket.io per casi d'uso in tempo reale. Utilizzare l'estensione Flask-socketio. | Adatto grazie all'architettura event-driven e ai moduli di streaming. Intrinsecamente asincrono. |
10 | Biblioteche | Più maturo e stabile. | Meno maturo e stabile, ma con sviluppo attivo e rilascio di correzioni. |
11 | Codice Qualità | È stato creato esclusivamente per il back-end. | A volte è compromesso a causa del passaggio di nuovi sviluppatori del front-end al back-end. |
12 | Composizione del team di sviluppatori | I team sono solitamente composti da sviluppatori back end e front end. Le preoccupazioni sono separate. | Gli sviluppatori possono scambiarsi i ruoli e lavorare sia per il front-end che per il back-end. |
13 | Integrazione con i sistemi e le applicazioni esistenti | Facilità di integrazione con altre applicazioni legacy backend esistenti grazie all'ecosistema Python per le applicazioni di Machine Learning e Big Data. | È abbastanza nuovo e richiede la creazione di librerie personalizzate o nuove per l'integrazione con altre applicazioni esistenti. |
Domande frequenti
D #1) Cosa dovrei imparare prima, Django o Flask?
Risposta: Una volta acquisita un po' di esperienza nello sviluppo web, si può passare a Django, che presuppone che si conosca già il funzionamento delle applicazioni web e si occupa da solo della maggior parte delle funzionalità.
D #2) È meglio Flask o Django?
Risposta: Sia Flask che Django sono eccellenti e adatti al loro scopo. Django è usato per creare applicazioni di maggior rilievo su scala aziendale, mentre Flask è usato per creare applicazioni statiche e di dimensioni ridotte. Flask è anche adatto per la prototipazione. Tuttavia, con l'uso delle estensioni di Flask, possiamo creare anche applicazioni di grandi dimensioni.
D #3) Quali aziende utilizzano Flask?
Risposta: Alcune delle aziende che utilizzano Flask sono Reddit, Mailgun, Netflix, Airbnb, ecc.
D #4) Quali siti utilizzano Django?
Risposta: Alcuni dei siti che utilizzano Django sono Instagram, Spotify, YouTube, Dropbox, Bitbucket, Eventbrite, ecc.
Conclusione
Non dovremmo fissarci a lungo su un unico framework, ma essere pronti ad apprendere nuove tecnologie e ad adottare gli stack più in voga. Alcuni di noi vogliono approcci comparativamente più semplici, con cicli di rilascio rigidi, che mantengano una più stretta compatibilità all'indietro, ecc.
Se pensate di appartenere più a questo gruppo, allora dovete scegliere Django. Tuttavia, è incredibile camminare con le nuove funzionalità e la flessibilità del framework Flask. Quando volete mantenere la coerenza tra il front-end e il back-end, potete scegliere un framework full-stack come NodeJS.
Scegliere un framework è più che altro una scelta che dipende dal contesto e dai problemi che cerchiamo di risolvere. La scelta di un framework è sempre difficile. Speriamo di aver presentato i punti di revisione essenziali in questo tutorial e che vi aiuterà a finalizzare un framework. Tuttavia, raccomandiamo di imparare entrambi i framework.
È più facile iniziare con Flask e poi passare a Django dopo aver acquisito un po' di esperienza nello sviluppo web. Se per qualche motivo i vostri sforzi di sviluppo richiedono l'uso di JavaScript, potete andare avanti con NodeJS.