【FastAPI】APIドキュメントに説明を追加する【入門】
当ページのリンクには広告が含まれています。
data:image/s3,"s3://crabby-images/0b89b/0b89beedfc8a74c1fd00a6adf80773d2ee808c5d" alt=""
FastAPI
にはとても便利な自動生成されるAPIドキュメントがあります。
このドキュメントはタグ
で分類したり、任意の説明文章を追加することが簡単にできますのでご紹介いたします。
FastAPIの基礎についての記事まとめ
目次
基本形
下記を基本形として追記していきます。
@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/0f0f8/0f0f84bd50ddae9dd800918d09d55c7144f675bd" alt=""
通常は、見出しにdefault
と表記されますが、デコレーターにtags=['tag_name']
とすることで任意のタグをつけることが出来ます。
@app.get('/article/all', tags=['article'])
def get_article(username: Optional[str] = None, is_display: bool = True):
return {'message': f'article all query {username} and {is_display}'}
article
タグを付けてみると・・・
data:image/s3,"s3://crabby-images/f9bf8/f9bf89b2bea19bc5459fe257061e6356d153f13b" alt=""
きちんと分類されています。このようにエンドポイントをタグで分類することが可能です。
説明文の追加
主に追加できる説明文は
- sumnmary
- description
- response_description
があり、docstring
による記載も可能です。
あわせて読みたい
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/f7984/f7984ebe85f18bf53ae87b273284eb81972858c4" alt=""
Path Operationの高度な設定 – FastAPI
FastAPI framework, high performance, easy to learn, fast to code, ready for production
@app.get(
'/article/all',
summary='All Articles',
description='Get All Articles',
response_description='response',
tags=['article']
)
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/491ab/491ab2ccc25f61cd61036cd0f291d2b8c8331427" alt=""
docstring
で記載する場合には
@app.get(
'/article/all',
response_description='response',
tags=['article']
)
def get_article(username: Optional[str] = None, is_display: bool = True):
"""
Get All Articles
- ***username*** optional username
- ***is_display*** default True
docstring
"""
return {'message': f'article all query {username} and {is_display}'}
data:image/s3,"s3://crabby-images/a50bd/a50bdea7544c2be39904bc90215269c2bd3d2c74" alt=""
こんな感じで記載されます。便利!
FastAPIの基礎についての記事まとめ
コメント