Python の Web 開発フレームワークを開始する方法を段階的に説明します。

WBOY
リリース: 2023-04-11 13:40:03
転載
1914 人が閲覧しました

Python の Web 開発フレームワークを開始する方法を段階的に説明します。

Web開発フレームワークというと、私は普段FlaskとDjangoを使っていますが、Flaskは軽量な開発フレームワークで、APIインターフェースを書くのにとても便利なのですが、FastAPIフレームワークは今回紹介するモジュールもPython開発者の間で評判が良いので、始める前にpipコマンドで使用するモジュールをインストールする必要があります。

pip install fastapi
ログイン後にコピー

ASGI サーバーは uvicorn を使用できるため、同様です。

pip install uvicorn
ログイン後にコピー

HelloWorld

まず、Flask フレームワークを使用して HelloWorld を作成してみます。コードは次のとおりです:

from flask import Flask, request
import json
app = Flask(__name__)
@app.route('/')
def hello_world():
 return 'hello world'
if __name__ == '__main__':
 app.run(host='0.0.0.0', port=8889)
ログイン後にコピー

エディターで使用される開発ツールは Pycharm です。このスクリプトを実行すると、次の結果がポップアップ表示されます。

Python の Web 開発フレームワークを開始する方法を段階的に説明します。

次に、ブラウザにポップアップ URL を入力してページにアクセスすると、以下のような「hello world」を含むページが表示されます。

Python の Web 開発フレームワークを開始する方法を段階的に説明します。

コードのロジックから、app = Flask(__name__) は Flask プログラム インスタンスを作成します。ブラウザに URL を入力して Web サーバーにリクエストを送信します。サーバーは URL を Flask プログラム インスタンスに転送するため、URL と Python 関数の間のマッピング関係が保存されるように、URL リクエストごとにコードのどの部分を開始する必要があるかを知る必要があります。上記 2 つの関係を処理するために使用されるプログラム インスタンス app.route デコレータを実現します。最後の app.run() を実行してサービスを開始します。0.0.0.0 はすべてのアドレスをリッスンすることを意味し、指定されたポート番号は 8889 です。それでは、対応する FastAPI バージョンの「HelloWorld」がどのようなものかを見てみましょう。次のように:

from fastapi import FastAPI
from fastapi.responses import PlainTextResponse, HTMLResponse, FileResponse
import uvicorn
app = FastAPI()
@app.get("/", response_class=PlainTextResponse)
async def hello(): ## async可加可不加,这个随意
 return "Hello World!"
@app.get("/items/{item_id}")
def read_item(item_id: int, q: str = None):
 return {"item_id": item_id, "q": q}
if __name__ == '__main__':
 uvicorn.run('fast_api_1:app', host='0.0.0.0', port=8000)
ログイン後にコピー

このコードも実行します。FastAPI のデフォルトのリスニング アドレスは 127.0.0.1 で、指定されたポート番号は 8000 なので、http://127.0.0.1:8000/ と入力します。結果は以下のようになります 表示:

Python の Web 開発フレームワークを開始する方法を段階的に説明します。

文字列が返されるので、response_classにPlainTextResponseを記入し、ブラウザに http://127.0 と入力することもできます。 :8000/items/5?q=somequery、結果は次のようになります:

Python の Web 開発フレームワークを開始する方法を段階的に説明します。

乱数を返します

私たちは上記の "Hello World" にいます。これに基づいて、乱数を返す操作など、さらにいくつかのケースを書いてみましょう。Flask フレームワークのコードは次のとおりです:

@app.route('/random-number')
def random_number():
 return str(random.randrange(100))
ログイン後にコピー

以下に示すように、ブラウザで結果をテストしてみましょう:

Python の Web 開発フレームワークを開始する方法を段階的に説明します。

FastAPI フレームワークのコードも非常に似ています。

@app.get('/random-number', response_class=PlainTextResponse)
async def random_number():
 return str(random.randrange(100))
ログイン後にコピー

すべて文字で構成されているかどうかを判定

次に見てみましょう、GETリクエストを送信する際に、URLリクエストパラメータのいずれかが文字で構成されているかどうかを判定します。 Flask フレームワークのコードは次のとおりです:

@app.route('/alpha', methods=['GET'])
def alpha():
 text = request.args.get('text', '')
 result = {'text': text, 'is_alpha' : text.isalpha()}
 return jsonify(result)
ログイン後にコピー

以下に示すように、ブラウザで結果をテストしてみましょう:

Python の Web 開発フレームワークを開始する方法を段階的に説明します。

一方、 FastAPI フレームワーク 対応するコードは次のとおりです:

@app.get('/alpha')
async def alpha(text: str):
 result = {'text': text, 'is_alpha' : text.isalpha()}
return result
ログイン後にコピー

Create a new user

上記のケースはすべて GET リクエストです。POST リクエストの処理方法を見てみましょう。 POST リクエストを通じて新しいユーザーを作成したい。新しいユーザーの場合、Flask フレームワークのコードは次のとおりです:

@app.route('/create-user', methods=['POST'])
def create_user():
 id = request.form.get('id', '0001')
 name = request.form.get('name', 'Anonymous')
 data = {'id': id, 'name': name}
 result = {'status_code': '0', 'status_message' : 'Success', 'data': data}
 return jsonify(result)
ログイン後にコピー

以下に示すように、Postman で API の機能を直接テストできます:

Python の Web 開発フレームワークを開始する方法を段階的に説明します。

POST リクエストを使用するかどうかを「メソッド」で指定する必要がありますが、FastAPI フレームワークでは指定する必要はなく、 app.post() デコレーターを使用するだけです。

@app.post('/create-user')
async def create_user(id: str = Form(...), name: str = Form(...)):
 data = {'id': id, 'name': name}
 result = {'status_code': '0', 'status_message' : 'Success', 'data': data}
 return result
ログイン後にコピー

静的ページに戻る

静的ページを返す必要がある場合、Flask フレームワークのコードは次のようになります。

@app.route('/get-webpage', methods=['GET'])
def get_webpage():
 return render_template('flask_1.html', message="Contact Us")
ログイン後にコピー

FastAPI フレームワークでは少し面倒ですが、コードは次のとおりです:

app.mount("/static", StaticFiles(directory="static"), name="static")
## 用来加载静态页面
templates = Jinja2Templates(directory="templates")
@app.get('/get-webpage', response_class=HTMLResponse)
async def get_webpage(request: Request):
 return templates.TemplateResponse("index.html", {"request": request, "message": "Contact Us"})
ログイン後にコピー

静的なページが返されるので、response_class は HTMLResponse

に相当します。概要

上で書いたすべての Flask コードを次のように要約しましょう:

from flask import Flask, request, render_template
import random
from flask import jsonify
import json
app = Flask(__name__)
@app.route('/')
def hello_world():
 return 'hello world'
@app.route('/random-number')
def random_number():
 return str(random.randrange(100))
@app.route('/alpha', methods=['GET'])
def alpha():
 text = request.args.get('text', '')
 result = {'text': text, 'is_alpha' : text.isalpha()}
 return jsonify(result)
@app.route('/create-user', methods=['POST'])
def create_user():
 id = request.form.get('id', '0001')
 name = request.form.get('name', 'Anonymous')
 data = {'id': id, 'name': name}
 result = {'status_code': '0', 'status_message' : 'Success', 'data': data}
 return jsonify(result)
@app.route('/get-webpage', methods=['GET'])
def get_webpage():
 return render_template('flask_1.html', message="Contact Us")
if __name__ == '__main__':
 app.run(host='0.0.0.0', port=8889)
ログイン後にコピー

而将所有的FastAPI框架下的代码全部汇总到一起,则如下所示:

from fastapi import FastAPI, Request, Form
import uvicorn
from fastapi.staticfiles import StaticFiles
from fastapi.responses import PlainTextResponse, HTMLResponse, FileResponse
import random
from fastapi.templating import Jinja2Templates
app = FastAPI()
app.mount("/templates", StaticFiles(directory="templates"), name="templates")
templates = Jinja2Templates(directory="templates")
@app.get("/", response_class=PlainTextResponse)
async def hello():
 return "Hello World!"
@app.get("/items/{item_id}")
def read_item(item_id: int, q: str = None):
 return {"item_id": item_id, "q": q}
@app.get('/random-number', response_class=PlainTextResponse)
async def random_number():
 return str(random.randrange(100))
@app.get('/get-webpage', response_class=HTMLResponse)
async def get_webpage(request: Request):
 return templates.TemplateResponse("index.html", {"request": request, "message": "Contact Us"})
if __name__ == '__main__':
uvicorn.run('fast_api_1:app', host='0.0.0.0', port=8000)
ログイン後にコピー

以上がPython の Web 開発フレームワークを開始する方法を段階的に説明します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:51cto.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!