第7章. フレームワークの比較
この作品はAIを使って翻訳されている。ご意見、ご感想をお待ちしている:translation-feedback@oreilly.com
骨組みは必要ない。必要なのは絵画であってフレームではない。
クラウス・キンスキー(俳優
プレビュー
、Flask、Django、または一般的なPythonウェブフレームワークを使用したことがある開発者にとって、この章はFastAPIの類似点と相違点を指摘する。 そうでなければ、この本を束ねる接着剤にならないため、耐え難い細部には触れない。 この章の比較は、これらのフレームワークからFastAPIにアプリケーションを移行しようと考えている場合、または単に興味がある場合に役立つ。
新しいウェブフレームワークについて最初に知りたいことの一つは、どうやって始めるかであり、トップダウンの方法は、ルート(URLやHTTPメソッドから関数へのマッピング)を定義することである。 次のセクションでは、FastAPIとFlaskでこれを行う方法を比較する。なぜなら、これらはDjangoよりも互いに似ており、同じようなアプリケーションのために一緒に検討される可能性が高いからである。
Flask
Flaskは、 自身をマイクロフレームワークと呼んでいる。基本的な機能は提供されており、必要に応じてサードパーティのパッケージをダウンロードして補完する。 Djangoよりも小さく、使い始めのうちは習得が早い。
FlaskはASGIではなくWSGIをベースとした同期型である。quartという新しいプロジェクトがFlaskを複製し、ASGIサポートを追加している。
FlaskとFastAPIがどのようにWebルーティングを定義しているのか、トップから見ていこう。
パス
トップレベルでは、 FlaskもFastAPIも、デコレーターを使ってルートとWebエンドポイントを関連付ける。例7-1では、URLパスから挨拶する人を取得する例3-11(第3章に戻る)を重複させてみよう。
例 7-1. FastAPI パス
fromfastapiimportFastAPIapp=FastAPI()@app.get("/hi/{who}")defgreet(who:str):returnf"Hello?{who}?"
デフォルトでは、FastAPI はf"Hello? {who}?" 文字列を JSON に変換し、ウェブクライアントに返す。
例7-2は、Flaskがそれを行う方法を示している。
例7-2. Flaskパス
fromflaskimportFlask,jsonifyapp=Flask(__name__)@app.route("/hi/<who>",methods=["GET"])defgreet(who:str):returnjsonify(f"Hello?{who}?")
デコレーターのwho が、< と> で囲まれていることに注目してほしい。Flaskでは、メソッドを引数として含める必要がある-デフォルトのGET を除いて。methods=["GET"] を省略することもできたが、明示的であることに越したことはない。
注
Flask 2.0は、app.route の代わりに@app.getのようなFastAPIスタイルのデコレーターをサポートしている。
Flaskのjsonify() 関数は、引数をJSON文字列に変換し、JSONであることを示すHTTPレスポンスヘッダとともに返す。(他のデータ型ではなく) ...
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