【FastAPI】パラメータ・リクエストボディの使い方【入門】
data:image/s3,"s3://crabby-images/a6d75/a6d759e8678e768bd1baeea2f7410ff61af61a04" alt=""
FastAPI
では、簡単に受け取るパラメーターやリクエストボディの記述が可能です。
今回は、パス・クエリパラメーターやリクエストボディの記述方法をご紹介いたします。
data:image/s3,"s3://crabby-images/7ebe0/7ebe08e6511092c48c29f9e633865aae31a94834" alt=""
FastAPIの基礎についての記事まとめ
パスパラメーターの付与
URL
に任意のパラメーターを受け取る場合には、{id}
と引数を受け取ります。
data:image/s3,"s3://crabby-images/4c32b/4c32b7ac777b04cc36f165ba42b11c1c1de1a4c5" alt=""
@app.get('/article/{id}')
def get_article(id):
return {'message': f'article is {id}'}
data:image/s3,"s3://crabby-images/e90c0/e90c04842256063b27f48518375ee422aee3b21f" alt=""
受け取るパラメーターは、int, str, bool
などで型指定が可能です。
@app.get('/article/{id}')
def get_article(id: int): <-- int
return {'message': f'article is {id}'}
data:image/s3,"s3://crabby-images/fa1ff/fa1ff004adb421b140192ba467cf3d41ca8b0618" alt=""
複数のパラメータを受け取ることも可能です。
@app.get('/article/{id}/comments/{comment_id}')
def get_article(id: int, comment_id: int):
return {'message': f'article is {id} and {comment_id}'}
data:image/s3,"s3://crabby-images/d8216/d82167d831bb000693fc68d23705cbf0184501f2" alt=""
クエリパラメーターの付与
http://127.0.0.1/article/all?username=name&is_display=true
のようなクエリパラメーターを付与する場合も同様です。
data:image/s3,"s3://crabby-images/eab02/eab022401420358648974acf228732de63e36e9d" alt=""
@app.get('/article/all')
def get_article(username: str, is_display: bool = True):
return {'message': f'article all query {username} and {is_display}'}
リクエストボディ
POST
メソッドなどでボディを受け取る場合には、pydantic
からBaseModel
をインポートして継承したクラスを作成します。
data:image/s3,"s3://crabby-images/06a7e/06a7eb6236940177a04acdc012db7ae742341bd9" alt=""
作成したモデルを、aritcle: ArticleModel
としています。
from pydantic import BaseModel
from typing import Optional
~~~
class ArticleModel(BaseModel):
title: str
content: str
username: str
is_display: Optional[bool]
@app.post('/article')
def get_article(article: ArticleModel, username: Optional[str] = None, is_display: bool = True):
return {
'article': article,
'username': username,
'is_display': is_display
}
ドキュメントを起動して、試しに送信してみましょう。適当な文字列を入力しました。
data:image/s3,"s3://crabby-images/024f4/024f459fcb0735a17c8a8129c7d1691ed72a25a9" alt=""
data:image/s3,"s3://crabby-images/25dba/25dba397d5c95a4d89895371323fffb18228a2e7" alt=""
パス・クエリパラメーター、リクエストボディ全てを受け取れました。
複雑なクエリパラメーターやリクエストボディの記述方法
必須にしない(Optional)
クエリパラメーターやリクエストボディを必須にしない場合には、python
の型ヒントを活用してOptional
を用います。
data:image/s3,"s3://crabby-images/6f4a2/6f4a24e571ef508e47f42aff315ed7f4b07bc1fc" alt=""
今回の例ではusername
をusername: Optional[str] = None
とし、任意の値に指定します。
from typing import Optional
~~~
@app.get('/article/all')
def get_article(username: Optional[str] = None, is_display: bool = True):
return {'message': f'article all query {username} and {is_display}'}
ドキュメントを確認すると必須ではなくなっていることが確認できました。
data:image/s3,"s3://crabby-images/be550/be55060e3998e13f88e4921a3b6023cc8653418c" alt=""
リストや辞書形式での定義(List, Dict)
リストや辞書形式など複雑な構造を持つ場合には、typing
からList
やDict
をインポートします。
from pydantic import BaseModel
from typing import Optional, List, Dict
~~~
class ArticleModel(BaseModel):
title: str
content: str
username: str
tag: List[str] = []
metadata: Dict[str, str] = {'key': 'value'}
@app.post('/article')
def get_article(article: List[ArticleModel], username: Optional[str] = None, is_display: bool = True):
return {
'article': article,
'username': username,
'is_display': is_display
}
ドキュメントを確認すると、リスト、辞書型が受け取れました。
data:image/s3,"s3://crabby-images/3fe5c/3fe5c794be574a13e55d75e356ee523f5ad32792" alt=""
metaデータやバリデーションの追加
クエリパラメータを明示して、様々なオプションを活用する場合にはfastapi
から
Path
パスパラメーターQuery
クエリパラメーターBody
リクエストボディ
をそれぞれインポートします。引数に関してはほとんど共通です。
data:image/s3,"s3://crabby-images/8c02a/8c02a951aa41226e3f2a519e09f1e8ec5107a695" alt=""
これらを活用すると
- 複数のリストを値を受け取る
- metaデータの追加
alias
title
description
deprecated
- 文字列のバリデーション
min_length
max_length
regex
- 数値のバリデーション
gt
:g
reatert
hange
:g
reater than ore
quallt
:l
esst
hanle
:l
ess than ore
qual
メタデータやバリデーションの追加が可能です。
FastAPIの基礎についての記事まとめ
コメント