FastAPI是一種Python web框架,允許映射復(fù)雜的JSON對象。
首先,我們需要安裝FastAPI和Pydantic模塊,在命令行中輸入以下命令:
pip install fastapi
pip install uvicorn
pip install pydantic
在FastAPI中,我們可以使用Pydantic模型來映射JSON對象。下面是一個(gè)簡單的示例:
from fastapi import FastAPI
from pydantic import BaseModel
app = FastAPI()
class Item(BaseModel):
name: str
price: float
is_offer: bool = None
@app.post("/items/")
async def create_item(item: Item):
return item
在這個(gè)示例中,我們定義了一個(gè)Item模型,它有三個(gè)字段:name、price和is_offer。 在create_item函數(shù)中,我們使用FastAPI的post裝飾器將其設(shè)置為POST請求,并將item參數(shù)設(shè)置為Item類型。然后,我們返回接收到的JSON對象。
如果我們向該API發(fā)送以下JSON對象:
{
"name": "apple",
"price": 1.5
}
我們將獲得以下響應(yīng):
{
"name": "apple",
"price": 1.5,
"is_offer": null
}
注意,is_offer字段初始化為None。這是因?yàn)槲覀冊贗tem模型中定義了它的默認(rèn)值為None。如果我們不提供is_offer字段,它將自動(dòng)初始化為None。
FastAPI還支持嵌套模型。例如,如果我們有一個(gè)名為User的模型和一個(gè)名為ItemCollection的模型,前者包含一個(gè)User對象和一個(gè)Item對象列表:
class User(BaseModel):
username: str
password: str
class ItemCollection(BaseModel):
user: User
items: List[Item]
@app.post("/items/")
async def create_item(item_collection: ItemCollection):
return item_collection
在上面的示例中,我們定義了一個(gè)包含user和items字段的ItemCollection模型。 在create_item函數(shù)中,我們將item_collection參數(shù)設(shè)置為ItemCollection類型。 然后我們可以訪問item_collection.user和item_collection.items字段。
總之,F(xiàn)astAPI使映射復(fù)雜JSON對象變得非常簡單。與Pydantic模型配合使用,我們可以輕松地定義我們的API的請求和響應(yīng)體。