2

我正在使用 FastAPI、Pydantic、SQLAlchemy 和 Postgres 来构建一个接收 post 请求并将数据存储在数据库中的服务。Pydantic 模型中有一个List,如下所示:

from typing import List
from pydantic import BaseModel, Field

class Note(base model):
    id: int
    title: str
    authors: List[str]

和表:

notes = Table(
    "notes",
    metadata,
    Column("id", Integer, primary_key=True),
    Column("title", String),
    Column("authors", ARRAY(String(50), dimensions=3)),
)

当没有List值时,这是我执行发布请求的方式:

def post(payload: Note):
    query = questions.insert().values(title=payload.title)
    return database.execute(query=query)

发布请求的正文:

{
    "title": "some value"
}

它工作正常。但是添加List值会因 Pydantic 的验证错误而破坏它:

def post(payload: Note):
    query = questions.insert().values(title=payload.title, authors=payload.authors)
    return database.execute(query=query)
{
    "title": "some value",
    "authors": ["name1", "name2", "name3"]
}

值不是有效列表

type_error.list

如何更改发布功能和请求正文以使其正常工作?

编辑:回溯:

ERROR:    Exception in ASGI application
Traceback (most recent call last):
  File "/usr/lib/python3/dist-packages/uvicorn/protocols/http/httptools_impl.py", line 385, in run_asgi
    result = await app(self.scope, self.receive, self.send)
  File "/usr/lib/python3/dist-packages/uvicorn/middleware/proxy_headers.py", line 45, in __call__
    return await self.app(scope, receive, send)
  File "/home/saeed/.local/lib/python3.8/site-packages/fastapi/applications.py", line 149, in __call__
    await super().__call__(scope, receive, send)
  File "/home/saeed/.local/lib/python3.8/site-packages/starlette/applications.py", line 102, in __call__
    await self.middleware_stack(scope, receive, send)
  File "/home/saeed/.local/lib/python3.8/site-packages/starlette/middleware/errors.py", line 181, in __call__
    raise exc from None
  File "/home/saeed/.local/lib/python3.8/site-packages/starlette/middleware/errors.py", line 159, in __call__
    await self.app(scope, receive, _send)
  File "/home/saeed/.local/lib/python3.8/site-packages/starlette/exceptions.py", line 82, in __call__
    raise exc from None
  File "/home/saeed/.local/lib/python3.8/site-packages/starlette/exceptions.py", line 71, in __call__
    await self.app(scope, receive, sender)
  File "/home/saeed/.local/lib/python3.8/site-packages/starlette/routing.py", line 550, in __call__
    await route.handle(scope, receive, send)
  File "/home/saeed/.local/lib/python3.8/site-packages/starlette/routing.py", line 227, in handle
    await self.app(scope, receive, send)
  File "/home/saeed/.local/lib/python3.8/site-packages/starlette/routing.py", line 41, in app
    response = await func(request)
  File "/home/saeed/.local/lib/python3.8/site-packages/fastapi/routing.py", line 204, in app
    response_data = await serialize_response(
  File "/home/saeed/.local/lib/python3.8/site-packages/fastapi/routing.py", line 126, in serialize_response
    raise ValidationError(errors, field.type_)
pydantic.error_wrappers.ValidationError: 1 validation error for Note
response
  value is not a valid list (type=type_error.list)
4

3 回答 3

2

我想通了。通过修复respone_model有错误的问题解决了问题,并且我为存储数据所做的一切都是正确的。

@router.post("/", response_model=Note, status_code=201)
def create_note(payload: Note):
    note_id = post(payload)
    response_object = {
        "id": note_id,
        "title": payload.title,
        "authors": payload.authors,
    }
    return response_object
于 2020-05-10T20:59:47.103 回答
0
@router.get("/fetchusuarios", response_model=List[providers.schemas.User])
async def fetchall_users(db:Session=Depends(get_db)):
    usuarios = db.query(models.usermodel.User).all()
    return usuarios
于 2021-09-05T04:37:09.753 回答
0

我使用的是 Django-Ninja(基于 FastAPI)并且遇到了同样的错误。最初,我的装饰器是这样的:

@router.get('/apartment-sale-hanoi/', response=List[ApartmentSaleHanoiSchema])

value is not a valid list (type=type_error.list)我只是通过从响应模型中删除来修复List如下:

@router.get('/apartment-sale-hanoi/', response=ApartmentSaleHanoiSchema)

我的返回响应(显示为 JSON)是一个对象列表

response = ApartmentSaleHanoi.objects.all()
于 2022-02-08T16:49:29.850 回答