検索
ホームページバックエンド開発Python チュートリアルFastAPIでAPIドキュメントの自動生成とUI表示を実装する方法

FastAPI で API ドキュメントの自動生成と UI 表示を実装する方法

FastAPI のような強力な Python フレームワークを使用すると、高パフォーマンスの Web API を簡単に構築できます。ただし、API を構築する際には、他の開発者が API を理解して使用できるように、明確でわかりやすい API ドキュメントも必要です。この記事では、FastAPI を使用して API ドキュメントを自動生成し、UI に表示する方法を紹介します。

まず、FastAPI と関連する依存ライブラリをインストールする必要があります。コマンド ラインで次のコマンドを実行してインストールします:

pip install fastapi
pip install uvicorn
pip install fastapi_utils

次に、必要なモジュールをインポートする必要があります:

from fastapi import FastAPI
from fastapi_utils.api_model import APIModel
from fastapi_utils.api_doc import APIModelDoc

次に、FastAPI のインスタンスを作成します:

app = FastAPI()

次に、API モデルを定義できます。 API モデルは、FastAPI によって提供される APIModel クラスを使用して定義されます。このクラスには、API リクエストとレスポンスのフィールドを含めることができます。

class User(APIModel):
    id: int
    name: str
    email: str

FastAPI アプリケーションでは、このモデルを使用して API ルーティングとロジックを定義できます。

@app.get("/users/{user_id}", response_model=User, summary="Get user by ID", tags=["users"])
def get_user(user_id: int):
    return {"id": user_id, "name": "John Doe", "email": "johndoe@example.com"}

上記のコードでは、HTTP GET リクエストのルート /users/{user_id} を定義し、応答モデルを User として指定します。また、ルートに簡単な説明とラベルを追加しました。これは、後で API ドキュメントを整理およびフィルタリングするために使用できます。

次に、APIModelDoc クラスを使用して、API モデルのドキュメントを生成します。

docs = APIModelDoc(app)
docs.register(User)

上記のコードにより、API モデルが API ドキュメントに登録されます。

最後に、docs.html メソッドを使用して、自動生成された API ドキュメントの HTML コードを取得する必要があります。

@api.route('/docs', method="GET", tags=["docs"])
def get_docs():
    return docs.html()

上記のコードでは、GET ルート /docs を定義し、自動生成された API ドキュメントの HTML コードを返します。ここでは、API ドキュメント内でフィルタリングおよび整理するために、このルートにタグ docs を追加しました。

次に、FastAPI アプリケーションを実行して、自動的に生成された API ドキュメントを表示しましょう。

if __name__ == "__main__":
    uvicorn.run(app, host="0.0.0.0", port=8000)

コマンド ラインで次のコマンドを実行してアプリケーションを起動します。

python app.py

次に、ブラウザで http://localhost:8000/docs にアクセスします。自動生成された API ドキュメントを確認できます。

上記の手順により、FastAPI で API ドキュメントの自動生成と UI 表示を実装することができました。 API ドキュメントのスタイルとコンテンツをニーズに合わせてさらにカスタマイズおよび調整できます。

この記事が、FastAPI を使用して強力な API を構築するのに役立ち、API に関する明確でわかりやすいドキュメントを提供できることを願っています。

以上がFastAPIでAPIドキュメントの自動生成とUI表示を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Python:編集と解釈に深く掘り下げますPython:編集と解釈に深く掘り下げますMay 12, 2025 am 12:14 AM

pythonusesahybridmodelofcompilation andtertation:1)thepythoninterpretercompilessourcodeodeplatform-indopent bytecode.2)thepythonvirtualmachine(pvm)thenexecuteTesthisbytecode、balancingeaseoputhswithporformance。

Pythonは解釈されたものですか、それとも編集された言語であり、なぜそれが重要なのですか?Pythonは解釈されたものですか、それとも編集された言語であり、なぜそれが重要なのですか?May 12, 2025 am 12:09 AM

pythonisbothintersedand compiled.1)it'scompiledtobytecode forportabalityacrossplatforms.2)bytecodeisthenは解釈され、開発を許可します。

ループ対pythonのループの場合:説明されたキーの違いループ対pythonのループの場合:説明されたキーの違いMay 12, 2025 am 12:08 AM

loopsareideal whenyouwhenyouknumberofiterationsinadvance、foreleloopsarebetterforsituationsは、loopsaremoreedilaConditionismetを使用します

ループのために:実用的なガイドループのために:実用的なガイドMay 12, 2025 am 12:07 AM

henthenumber ofiterationsisknown advanceの場合、dopendonacondition.1)forloopsareideal foriterating over for -for -for -saredaverseversives likelistorarrays.2)whileopsaresupasiable forsaresutable forscenarioswheretheloopcontinupcontinuspificcond

Python:それは本当に解釈されていますか?神話を暴くPython:それは本当に解釈されていますか?神話を暴くMay 12, 2025 am 12:05 AM

pythonisnotpurelyLepted; itusesahybridapproachofbytecodecodecodecodecodecodedruntimerttation.1)pythoncompilessourcodeintobytecode、whodythepythonvirtualmachine(pvm).2)

同じ要素を持つPython Concatenateリスト同じ要素を持つPython ConcatenateリストMay 11, 2025 am 12:08 AM

ToconcatenateListsinpythothesheElements、使用:1)Operatortokeepduplicates、2)asettoremoveduplicates、or3)listcomplunting for controloverduplicates、各メトドハスディフェルフェルフェントパフォーマンスアンドソーダーインプリテーション。

解釈対編集言語:Pythonの場所解釈対編集言語:Pythonの場所May 11, 2025 am 12:07 AM

pythonisantertedlanguage、useaseofuseandflexibility-butfactingporformantationationsincriticalapplications.1)解釈されたlikepythonexecuteline-by-lineを解釈します

ループのために:Pythonでそれぞれを使用するのはいつですか?ループのために:Pythonでそれぞれを使用するのはいつですか?May 11, 2025 am 12:05 AM

Useforloopswhenthenumberofiterationsisknowninadvance、andwhiloopswheniterationsdependonacondition.1)forloopsareidealforsecenceslikelistoranges.2)

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません