国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Table des matières
Démarrage" >Démarrage
Exécuter le développement " >Exécuter le développement
Validation " >Validation
. Post route
. ??>" >. ??>
有用的網(wǎng)址" >有用的網(wǎng)址
結(jié)論
Maison développement back-end Tutoriel Python Utilisation rapide de l'API REST par Python

Utilisation rapide de l'API REST par Python

Jun 15, 2020 pm 06:15 PM
python

Utilisation rapide de l'API REST par Python

à la suggestion d'un collègue, nous avons décidé d'utiliser Fastapi comme framework.

Fastapi est un framework basé sur Python qui encourage l'utilisation de Pydantic et OpenAPI (anciennement Swagger) pour la documentation, Docker pour un développement et un déploiement rapides, ainsi que des tests simples basés sur le framework Starlette.

Il offre de nombreux avantages tels que la validation et la documentation automatiques d'OpenAPI sans ajouter de surcharge inutile. Je pense qu'il existe un bon équilibre entre ne fournir aucune fonctionnalité intégrée et fournir trop de fonctionnalités intégrées.

Démarrage

Installez fastapi et le serveur ASGI (par exemple uvicorn)?:

Assurez-vous que vous utilisez Python 3.6.7+ Vous devrez peut-être utiliser pip et python si pip3 et python3 vous donnent une version python 2. Consultez également mon article sur la prise en main de Python.

pip?install?fastapi?uvicorn

et ajoutez l'ancien "hello world" dans le fichier main.py?:

from?fastapi?import?FastAPI

app?=?FastAPI()

@app.get("/")
def?home():
????return?{"Hello":?"World"}

Exécuter le développement

puis exécuter pour le développement, vous pouvez Exécutez uvicorn main:app --reload

C'est tout ce qu'un simple serveur fait?! Vous pouvez maintenant vérifier //localhost:8000/ pour voir la "Page d'accueil". Et, comme vous pouvez le constater, la réponse JSON ? fonctionne tout simplement ? ! Vous pouvez également obtenir l'interface utilisateur Swagger gratuitement sur //localhost:8000/docs.

Validation

Comme mentionné précédemment, il est facile de valider les données (et de générer une documentation Swagger pour les formats de données acceptés). Ajoutez simplement l'import Query depuis fastapi et utilisez-le pour forcer la validation?:

from?fastapi?import?FastAPI,?Query

@app.get('/user')
async?def?user(
????*,
????user_id:?int?=?Query(...,?title="The?ID?of?the?user?to?get",?gt=0)
):
??return?{?'user_id':?user_id?}

Le premier paramètre ... est la valeur par défaut qui est fournie si l'utilisateur ne fournit pas de valeur. S'il est défini sur None, il n'y a pas de valeur par défaut et le paramètre est facultatif. Pour n'avoir aucune valeur par défaut et que le paramètre soit obligatoire, utilisez plut?t Ellipsis , ou ....

Si vous exécutez ce code, vous verrez automatiquement la mise à jour sur l'interface utilisateur swagger?:

L'interface utilisateur Swagger vous permet d'afficher le nouvel itinéraire /user et utiliser spécifique Faire la demande avec un identifiant utilisateur

Si vous entrez un identifiant utilisateur, vous verrez qu'il effectuera automatiquement la demande pour vous, par exemple //localhost:8000/user?user_id=1. Dans la page, vous ne pouvez voir que l'ID utilisateur repris?!

Si vous souhaitez utiliser le paramètre path à la place (pour qu'il soit /user/1), entrez simplement et utilisez Path au lieu de Query. Vous pouvez également combiner les deux

. Post route

Si vous avez une route POST alors définissez simplement l'entrée

@app.post('/user/update')
async?def?update_user(
????*,
????user_id:?int,
????really_update:?int?=?Query(...)
):
????pass

Dans ce cas vous pouvez voir que le user_id n'est défini que comme un sans Query ou un entier de Path?; cela signifie qu'il sera dans le corps de la requête POST. Si vous acceptez des structures de données plus complexes, telles que les données JSON, vous devriez examiner les modèles de requête et de réponse

. ??>

Vous pouvez documenter et déclarer des modèles de demande et de réponse détaillés à l'aide des modèles Pydantic. Non seulement cela vous permet d'avoir une documentation OpenAPI automatique pour tous vos modèles, mais cela valide également les modèles de demande et de réponse pour garantir la saisie. . Toutes les données POST seront correctes et les données renvoyées seront également conformes au modèle

Déclarez simplement le modèle comme ceci?:

from?pydantic?import?BaseModel

class?User(BaseModel):
????id::?int
????name:?str
????email:?str
Ensuite, si vous voulez le modèle utilisateur en entrée, vous pouvez le faire. ce qui suit?:

async?def?update_user(*,?user:?User):
????pass
Ou si vous souhaitez l'utiliser comme sortie?:

@app.get('/user')
async?def?user(
????*,
????user_id:?int?=?Query(...,?title="The?ID?of?the?user?to?get",?gt=0),
????response_model=User
):
??my_user?=?get_user(user_id)
??return?my_user

Acheminer et décomposer une API plus grande

Vous L'API pouvez être divisé en itinéraires en utilisant

Par exemple, j'ai trouvé ceci dans mon API APIRouterapp / routers / v1 / __ init __。py

from?fastapi?import?APIRouter
from?.user?import?router?as?user_router

router?=?APIRouter()

router.include_router(
????user_router,
????prefix='/user',
????tags=['users'],
)
alors vous pouvez utiliser le code utilisateur ci-dessus dans

- importez simplement app / routers / v1 / user.py et utilisez au lieu de APIRouter. Il acheminera automatiquement vers @ router.get('/')< aaaa> car l'itinéraire est relatif au préfixe @ app.get('/ user')

from?fastapi?import?APIRouter

router?=?APIRouter()

@router.get('/')
async?def?user(
????*,
????user_id:?int?=?Query(...,?title="The?ID?of?the?user?to?get",?gt=0),
????response_model=User
):
??my_user?=?get_user(user_id)
??return?my_user
/ user / Enfin, utilisez tous les routeur, modifiez simplement pour?:

from?fastapi?import?FastAPI
from?app.routers?import?v1

app?=?FastAPI()

app.include_router(
????v1.router,
????prefix="/api/v1"
)
v1 Vous pouvez cha?ner les routeurs à volonté de cette fa?on, ce qui vous permet de diviser les grandes applications et de disposer d'API versionnées main.py

Dockerisation et déploiement

One. des choses que les auteurs de Fastapi ont faites est la Dockerisation étonnamment facile ! La valeur par défaut est de 2 lignes?!
FROM?tiangolo/uvicorn-gunicorn-fastapi:python3.7

COPY?./app?/app

是否想通過(guò)自動(dòng)重新加載進(jìn)行 Dockerize 開發(fā)?這是我在撰寫文件中使用的秘方:

version:?"3"
services:
??test-api:
????build:?..
????entrypoint:?'/start-reload.sh'
????ports:
????????-?8080:80
????volumes:
????????-?./:/app

這會(huì)將當(dāng)前目錄掛載為app并將在任何更改時(shí)自動(dòng)重新加載。您可能還想將app / app用于更大的應(yīng)用程序。

有用的網(wǎng)址

所有這些信息都來(lái)自 Fastapi網(wǎng)站,該文檔具有出色的文檔,我鼓勵(lì)您閱讀。此外,作者在 Gitter 上非?;钴S并樂(lè)于助人!

結(jié)論

就是這樣-我希望本指南對(duì)您有所幫助,并且您會(huì)像我一樣喜歡使用 Fastapi。

推薦教程:Python教程

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefa?on, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel PHP
1502
276
Comment utiliser PHP combiné avec l'IA pour obtenir la correction de texte de la syntaxe PHP détection et l'optimisation Comment utiliser PHP combiné avec l'IA pour obtenir la correction de texte de la syntaxe PHP détection et l'optimisation Jul 25, 2025 pm 08:57 PM

Pour réaliser la correction d'erreur de texte et l'optimisation de la syntaxe avec l'IA, vous devez suivre les étapes suivantes: 1. Sélectionnez un modèle ou une API d'IA appropriée, tels que Baidu, Tencent API ou bibliothèque NLP open source; 2. Appelez l'API via Curl ou Guzzle de PHP et traitez les résultats de retour; 3. Afficher les informations de correction d'erreur dans l'application et permettre aux utilisateurs de choisir d'adopter l'adoption; 4. Utilisez PHP-L et PHP_CODESNIFFER pour la détection de syntaxe et l'optimisation du code; 5. Collectez en continu les commentaires et mettez à jour le modèle ou les règles pour améliorer l'effet. Lorsque vous choisissez AIAPI, concentrez-vous sur l'évaluation de la précision, de la vitesse de réponse, du prix et du support pour PHP. L'optimisation du code doit suivre les spécifications du PSR, utiliser le cache raisonnablement, éviter les requêtes circulaires, revoir le code régulièrement et utiliser x

Python Seaborn JointPlot Exemple Python Seaborn JointPlot Exemple Jul 26, 2025 am 08:11 AM

Utilisez le plot conjoint de Seaborn pour visualiser rapidement la relation et la distribution entre deux variables; 2. Le tracé de diffusion de base est implémenté par sn.jointplot (data = pointes, x = "total_bill", y = "Tip", kind = "dispers"), le centre est un tracé de dispersion et l'histogramme est affiché sur les c?tés supérieur et inférieur et droit; 3. Ajouter des lignes de régression et des informations de densité à un kind = "reg" et combiner marginal_kws pour définir le style de tracé de bord; 4. Lorsque le volume de données est important, il est recommandé d'utiliser "Hex"

Python List to String Conversion Exemple Python List to String Conversion Exemple Jul 26, 2025 am 08:00 AM

Les listes de cha?nes peuvent être fusionnées avec la méthode join (), telles que '' .join (mots) pour obtenir "HelloworldFrompython"; 2. Les listes de nombres doivent être converties en cha?nes avec MAP (STR, nombres) ou [STR (x) Forxinnumbers] avant de rejoindre; 3. Toute liste de types peut être directement convertie en cha?nes avec des supports et des devis, adaptées au débogage; 4. Les formats personnalisés peuvent être implémentés par des expressions de générateur combinées avec join (), telles que '|' .join (f "[{item}]" ForIteminitems)

Python Connexion à SQL Server PyoDBC Exemple Python Connexion à SQL Server PyoDBC Exemple Jul 30, 2025 am 02:53 AM

Installez PYODBC: utilisez la commande PiPInstallpyodbc pour installer la bibliothèque; 2. Connectez SQLServer: utilisez la cha?ne de connexion contenant le pilote, le serveur, la base de données, l'UID / PWD ou TrustEd_Connection via la méthode pyoDBC.Connect () et prendre en charge l'authentification SQL ou l'authentification Windows respectivement; 3. Vérifiez le pilote installé: exécutez pyodbc.Drivers () et filtrez le nom du pilote contenant ?SQLServer? pour vous assurer que le nom du pilote correct est utilisé tel que ?ODBCDriver17 pour SQLServer?; 4. Paramètres clés de la cha?ne de connexion

Python pandas fondre l'exemple Python pandas fondre l'exemple Jul 27, 2025 am 02:48 AM

pandas.melt () est utilisé pour convertir les données de format larges en format long. La réponse consiste à définir de nouveaux noms de colonne en spécifiant id_vars conserver la colonne d'identification, Value_Vars Sélectionnez la colonne à fondre, var_name et valeur_name, 1.id_vars = 'name' signifie que la colonne de nom reste inchangée, 2.Value_vars = [Math ',' English ',' Science '. du nom de colonne d'origine, 4.value_name = 'score' définit le nouveau nom de colonne de la valeur d'origine et génère enfin trois colonnes, notamment le nom, le sujet et le score.

Optimisation de Python pour les opérations liées à la mémoire Optimisation de Python pour les opérations liées à la mémoire Jul 28, 2025 am 03:22 AM

PythonCanBeoptimizedFormemory-Boundoperations AdreductoverHeadHroughGenerators, EfficientDatastructures et ManagingObjectliFetimes.first, useGeneratorsInSteadofListStoproceSlargedataseSeItematatime, EvitingLoadingEnteryToMeToMeMory.

Python django forme l'exemple Python django forme l'exemple Jul 27, 2025 am 02:50 AM

Définissez d'abord un formulaire ContactForm contenant le nom, la bo?te aux lettres et les champs de message; 2. De l'avis, la soumission du formulaire est traitée en jugeant la demande de poste, et après la vérification, nettoyée_data est obtenue et la réponse est retournée, sinon le formulaire vide sera rendu; 3. Dans le modèle, utilisez {{form.as_p}} pour rendre le champ et ajouter {% csrf_token%} pour empêcher les attaques CSRF; 4. Configurer le routage d'URL vers Point / Contact / vers la vue Contact_View; Utilisez Modelform pour associer directement le modèle pour obtenir un stockage de données. Djangoforms implémente le traitement intégré de la vérification des données, le rendu HTML et les invites d'erreur, qui convient au développement rapide des fonctions de forme s?re.

Qu'est-ce que l'arbitrage statistique dans les crypto-monnaies? Comment fonctionne l'arbitrage statistique? Qu'est-ce que l'arbitrage statistique dans les crypto-monnaies? Comment fonctionne l'arbitrage statistique? Jul 30, 2025 pm 09:12 PM

L'introduction à l'arbitrage statistique L'arbitrage statistique est une méthode commerciale qui capture l'inadéquation des prix sur le marché financier basé sur des modèles mathématiques. Sa philosophie principale découle de la régression moyenne, c'est-à-dire que les prix des actifs peuvent s'écarter des tendances à long terme à court terme, mais reviendront éventuellement à leur moyenne historique. Les traders utilisent des méthodes statistiques pour analyser la corrélation entre les actifs et rechercher des portefeuilles qui changent généralement de manière synchrone. Lorsque la relation de prix de ces actifs est anormalement déviée, des opportunités d'arbitrage se présentent. Sur le marché des crypto-monnaies, l'arbitrage statistique est particulièrement répandu, principalement en raison de l'inefficacité et des fluctuations drastiques du marché lui-même. Contrairement aux marchés financiers traditionnels, les crypto-monnaies fonctionnent 24h / 24 et leurs prix sont très susceptibles de briser les nouvelles, les sentiments des médias sociaux et les améliorations technologiques. Cette fluctuation des prix constante crée fréquemment un biais de prix et fournit aux arbitrageurs un

See all articles