


Si vous êtes comme moi, vous avez probablement vu plusieurs approches différentes pour démarrer une application Flask et vous vous demandez laquelle est la meilleure. Parfois, vous rencontrerez manage.py, d'autres fois, vous verrez create_app. Cela peut prêter à confusion, surtout si vous débutez dans le développement de Flask ou si vous passez d'un projet à un autre.
Dans cet article, je vais vous présenter les méthodes les plus couramment utilisées pour démarrer une application Flask, en les décomposant avec des exemples clairs afin que vous puissiez décider ce qui fonctionne le mieux pour votre cas d'utilisation.
Méthode 1 : fichier app.py de base
Le moyen le plus simple de démarrer une application Flask consiste à créer un fichier app.py. C'est idéal pour les petites applications ou lorsque vous débutez avec Flask.
# app.py from flask import Flask app = Flask(__name__) @app.route('/') def home(): return "Welcome to my Flask app!" if __name__ == "__main__": app.run(debug=True)
Comment l'exécuter :
Dans votre terminal, accédez au dossier contenant app.py et exécutez :
python app.py
Flask démarrera sur localhost:5000 et vous pourrez visiter votre application dans un navigateur. C'est la méthode la plus rapide, mais elle présente des limites en termes de mise à l'échelle.
Méthode 2 : utilisation du modèle d'usine create_app
À mesure que votre application grandit, le modèle d'usine avec create_app() devient plus utile. Cette méthode permet de configurer et d'initialiser votre application de manière modulaire, vous permettant de mieux gérer les configurations complexes.
# app.py from flask import Flask def create_app(): app = Flask(__name__) @app.route('/') def home(): return "Hello from Factory Pattern!" return app
Comment l'exécuter :
Comme il n'y a pas de bloc if __name__ == "__main__", vous l'exécuterez en définissant la variable d'environnement FLASK_APP.
export FLASK_APP=app:create_app export FLASK_ENV=development flask run
Cette méthode est plus évolutive car elle permet une gestion plus facile de la configuration, ce qui la rend adaptée aux applications plus volumineuses ou utilisant des extensions.
Méthode 3 : Utilisation de manage.py avec Flask-Script
Bien que Flask-Script soit obsolète au profit de l'interface de ligne de commande (CLI) intégrée de Flask, certaines applications héritées utilisent toujours l'approche manage.py.
# manage.py from flask_script import Manager from app import create_app app = create_app() manager = Manager(app) if __name__ == "__main__": manager.run()
Pour exécuter l'application :
python manage.py runserver
Cette méthode étant désormais considérée comme obsolète, il est préférable de s'appuyer sur la CLI de Flask pour des fonctionnalités similaires.
Méthode 4 : Utiliser Gunicorn pour la production
Lors du déploiement d'une application Flask en production, vous souhaiterez utiliser un serveur WSGI comme Gunicorn au lieu du serveur de développement intégré de Flask.
Voici comment exécuter votre méthode create_app avec Gunicorn :
gunicorn 'app:create_app()'
Cela lancera votre application Flask en utilisant Gunicorn. Vous pouvez spécifier le nombre de processus de travail, l'hôte et le port si nécessaire :
gunicorn -w 3 -b 0.0.0.0:8000 'app:create_app()'
Méthode 5 : Utilisation de flask run pour la CLI intégrée
La CLI de Flask simplifie l'exécution de l'application et l'exécution d'autres commandes telles que les migrations. La CLI par défaut utilise les variables d'environnement FLASK_APP et FLASK_ENV.
export FLASK_APP=app.py export FLASK_ENV=development flask run
Cette commande exécute votre application en mode développement avec le rechargement à chaud et le mode débogage activés. C'est idéal pour le développement, mais vous ne devriez pas l'utiliser en production.
Lequel devriez-vous utiliser ?
- Petits projets ou prototypes : La méthode de base app.py fonctionne parfaitement.
- Applications volumineuses : optez pour le modèle d'usine create_app, car il s'adapte bien aux extensions et aux configurations complexes.
- Production : utilisez Gunicorn ou d'autres serveurs WSGI pour gérer plusieurs requêtes simultanément et offrir de meilleures performances.
Conclusion
Comprendre ces différentes méthodes vous donne de la flexibilité dans la façon dont vous démarrez une application Flask. Que vous construisiez un petit projet ou déployiez un système à grande échelle, vous trouverez l'approche adaptée à vos besoins. En comprenant les éléments essentiels de chaque méthode, vous serez en mesure de maintenir et de faire évoluer votre application efficacement.
Avez-vous utilisé une approche différente qui vous convient mieux ? Faites-le moi savoir dans les commentaires !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Créer des tableaux multidimensionnels avec Numpy peut être réalisé via les étapes suivantes: 1) Utilisez la fonction numpy.array () pour créer un tableau, tel que np.array ([[1,2,3], [4,5,6]]) pour créer un tableau 2D; 2) utiliser np.zeros (), np.ones (), np.random.random () et d'autres fonctions pour créer un tableau rempli de valeurs spécifiques; 3) Comprendre les propriétés de forme et de taille du tableau pour vous assurer que la longueur du sous-réseau est cohérente et éviter les erreurs; 4) Utilisez la fonction NP.Reshape () pour modifier la forme du tableau; 5) Faites attention à l'utilisation de la mémoire pour vous assurer que le code est clair et efficace.

BroadcastingInNumpyIsAmethodToperformOperations OnerwaysofdifferentShapesByAutomAticalAligningThem.itImplienScode, améliore la réadabilité et BoostsTerformance.He'showitwork

Forpythondatastorage, chooseListsforflexibilitywithMixedDatatyS, array.Arrayformmemory-efficienthomogeneousnumericalData, andNumpyArraysforaSvancedNumericalComputing.ListaSaRaySatilebutless

PythonlistsArebetterThanArraysformMagingDiversEDATATYPES.1) ListScan HoldingElementoSoFferentTypes, 2) Ils ont été aaredamique, permettant à la manière dont 4) ils ne sont pas entièrement efficaces et les opérations sont en train de les affirmer.

ToaccesElementsInapythonArray, useIndexing: my_array [2] AccessEstheThirdElement, returning3.pythonusZero-basedIndexing.

L'article discute de l'impossibilité de la compréhension des tuples dans Python en raison de l'ambiguïté de la syntaxe. Des alternatives comme l'utilisation de Tuple () avec des expressions de générateur sont suggérées pour créer efficacement les tuples. (159 caractères)

L'article explique les modules et les packages dans Python, leurs différences et leur utilisation. Les modules sont des fichiers uniques, tandis que les packages sont des répertoires avec un fichier __init__.py, organisant des modules connexes hiérarchiquement.

L'article traite des docstrings dans Python, de leur utilisation et des avantages. Problème principal: Importance des docstrings pour la documentation du code et l'accessibilité.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft

SublimeText3 version anglaise
Recommandé : version Win, prend en charge les invites de code !

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.
