如何在FastAPI中使用路徑參數進行參數化請求
FastAPI是一個快速(高效能),易於使用,以及基於標準API(例如,使用Pydantic和OpenAPI)開發的現代化Web框架。在FastAPI中,我們可以使用路徑參數來對請求進行參數化,以便更好地處理不同的請求。
路徑參數是指URL中的一部分,用來識別資源的特定實例。使用路徑參數能夠幫助我們根據不同的需求從Web API中取得特定的資料。以下將介紹如何在FastAPI中使用路徑參數進行參數化請求,並提供對應的程式碼範例。
首先,我們需要匯入FastAPI
和Path
模組,並建立一個app
物件:
from fastapi import FastAPI, Path app = FastAPI()
接下來,我們可以在路由路徑中定義路徑參數。路徑參數是由花括號包圍的字串,我們可以在其中定義參數的名稱和資料類型。例如,我們可以定義一個item_id
的路徑參數:
@app.get("/items/{item_id}") async def read_item(item_id: int): return {"item_id": item_id}
在上面的範例中,我們定義了一個/items/{item_id}
的路由路徑,並將路徑參數item_id
的資料型別定義為int
。在函數參數中,我們可以直接使用路徑參數的名稱item_id
來取得該值。
當我們向伺服器發送請求 /items/42
時,FastAPI將自動將路徑參數的值傳遞給對應的函數,並將其作為參數的值傳回。在上面的例子中,將傳回一個JSON對象,該對象包含參數的名稱和值:
{"item_id": 42}
我們也可以為路徑參數指定其他參數。例如,我們可以指定路徑參數的最小值和最大值。以下是一個範例:
@app.get("/users/{user_id}") async def read_user(user_id: int = Path(..., ge=1, le=100)): return {"user_id": user_id}
在上面的範例中,我們使用了ge
和le
兩個參數限制了user_id
的範圍,表示user_id
的值必須大於等於1且小於等於100。如果我們發送的請求中user_id
超出了這個範圍,FastAPI將會傳送一個HTTP異常回應。
除了常規的資料類型,我們還可以使用枚舉類型作為路徑參數的資料類型。以下是一個範例:
from enum import Enum class Size(str, Enum): small = "small" medium = "medium" large = "large" @app.get("/items/{item_id}/size/{size}") async def read_item_size(item_id: int, size: Size): return {"item_id": item_id, "size": size}
在上面的範例中,我們定義了一個Size
枚舉類,並將其作為參數size
的資料類型。當我們發送請求 /items/42/size/small
時,FastAPI會將路徑參數的值傳遞給對應的函數,並將其作為參數的值傳回。
使用路徑參數進行參數化請求是使用FastAPI處理Web API中不同請求的重要技術之一。透過路徑參數,我們可以定義不同的路由路徑,並根據不同的需求從伺服器中取得特定的資料。在上述範例中,我們示範如何使用路徑參數進行參數化請求,並提供了對應的程式碼範例。
總結一下,在FastAPI中使用路徑參數進行參數化請求的步驟如下:
Path
模組和FastAPI
庫。 app
物件作為應用程式的實例。 使用路徑參數能夠幫助我們更好地處理不同的請求,並準確地從伺服器中取得特定的資料。
參考文獻:
希望本文對您理解如何在FastAPI中使用路徑參數進行參數化請求有所幫助。
以上是如何在FastAPI中使用路徑參數進行參數化請求的詳細內容。更多資訊請關注PHP中文網其他相關文章!