第3章. FastAPIツアー
この作品はAIを使って翻訳されている。ご意見、ご感想をお待ちしている:translation-feedback@oreilly.com
FastAPIは、Pythonの標準的な型ヒントをベースに、Python 3.6+でAPIを構築するための、モダンで高速(高性能)なWebフレームワークである。
セバスチャン・ラミレス、FastAPIの開発者
プレビュー
FastAPIは2018年にSebastián Ramírez によって発表された。 多くの Python Web フレームワークよりも多くの利点があり、ここ数年で Python 3 に追加された機能を活用している。 この章では、FastAPI の主な機能の概要を、最初に知っておきたいこと、つまり Web リクエストとレスポンスの扱い方に重点を置いて説明する。
FastAPIとは何か?
どのウェブ・フレームワークもそうであるように、FastAPIはウェブ・アプリケーションの構築を助ける。 どのフレームワークも、機能、省略、デフォルトによって、いくつかの演算子をより簡単にするように設計されている。 FastAPIはその名の通り、ウェブAPIの開発をターゲットにしているが、従来のウェブ・コンテンツ・アプリケーションにも使うことができる。
FastAPIのWebサイトでは、このような利点を謳っている:
- パフォーマンス
-
場合によってはNode.jsやGoと同じくらい速く、Pythonフレームワークとしては異例だ。
- より迅速な開発
-
鋭利なエッジや変なところはない。
- コード品質の向上
-
タイプ・ヒンティングとモデルはバグを減らすのに役立つ。
- 自動生成ドキュメントとテストページ
-
OpenAPIの記述を手作業で編集するよりもずっと簡単だ。
FastAPIは以下を使用する:
-
Python型のヒント
-
非同期サポートを含むウェブ・マシナリー用Starlette
-
データ定義と検証のためのPydantic
-
他を活用し、拡張するための特殊化統合
この組み合わせは、ウェブ・アプリケーション、特にRESTfulなウェブ・サービスのための快適な開発環境となる。
FastAPI アプリケーション
小さなFastAPIアプリケーション(単一のエンドポイントを持つウェブサービス)を書いてみよう。 今のところ、ウェブレイヤーと呼んでいるところで、ウェブリクエストとレスポンスだけを処理する。 まず、これから使う基本的なPythonパッケージをインストールする:
-
FastAPIフレームワーク:
pip install fastapi -
Uvicornのウェブサーバだ:
pip install uvicorn -
HTTPieテキストウェブクライアント:
pip install httpie -
Requests同期ウェブクライアントパッケージ:
pip install requests -
HTTPX同期/非同期ウェブクライアントパッケージ:
pip install httpx
curlは最もよく知られたテキストウェブクライアントだが、HTTPieの方が使いやすいと思う。 また、デフォルトでJSONエンコーディングとデコーディングになっており、FastAPIとの相性が良い。 この章の後半で、特定のエンドポイントにアクセスするために必要なcurlコマンドラインの構文を含むスクリーンショットを見ることができる。
例3-1では、内向的なウェブ開発者になりきって、このコードを ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Read now
Unlock full access