- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
到目前为止,我有 2 个问题无法使用 docs/goole/stack info 解决:-)
1) 当使用模型作为 fastapi get 查询的查询输入时,我该如何捕获 pydantic 模型验证器装饰器抛出的 ValidationErrors?
上下文:
我有一个狂妄的模型:
class PointRankReqParams(BaseModel):
rat: Optional[Literal['2G', '3G', '4G', '5G']] = '3G'
h3resolution: Optional[int] = 5
input_srid: Optional[int] = 4326
bufferdistance: Optional[int] = 5000
x: float
y: float
@validator('h3resolution')
def h3resolution_bins(cls, v):
if v not in [4,5,6,7,8]:
raise ValueError('Hexabin size not permitted')
return v
和服务于 GET 请求的 FastAPI 函数:
@router.get("/point/overall", summary="GET Ranking for given location point")
async def get_ranking_for_location_point(inputparams: PointRankReqParams = Depends(),token: str = Depends(oauth2_scheme)):
logger.debug("Here I am")
return {}
现在,当我使用超出定义范围的参数 h3resolution curl 时,例如http://localhost:9000/rank/point/overall?rat=2G&h3resolution=9&input_srid=4326&bufferdistance=5000&x=21&y=21
我在控制台中收到实际上有意义的错误
py- | File "pydantic/main.py", line 406, in pydantic.main.BaseModel.__init__
py- | pydantic.error_wrappers.ValidationError: 1 validation error for PointRankReqParams
py- | h3resolution
py- | Hexabin size not permitted (type=value_error)
但是 FastAPI 向终端客户端返回 HTTP 500 内部服务器错误。我该如何捕获来自验证器的那些异常?
<强>2。如何正确使用 Optional[Literal[...]] 结构?
我试图重新定义上面的例子以在模型中使用:
class PointRankReqParams(BaseModel):
...
h3resolution: Optional[Literal[4,5,6,7,8]] = 5
但是当我 curl GET 查询时例如 http://localhost:9000/rank/point/overall?rat=2G&h3resolution=7&input_srid=4326&bufferdistance=5000&x=21&y=21
我收到 422 Unprocessable 条目,因为 h3resolution 被解释为字符串而不是整数:
{
"detail": [
{
"loc": [
"query",
"h3resolution"
],
"msg": "unexpected value; permitted: 4, 5, 6, 7, 8",
"type": "value_error.const",
"ctx": {
"given": "7",
"permitted": [
4,
5,
6,
7,
8
]
}
}
]
}
非常感谢!
最佳答案
这个问题问得好!这已经讨论了好几年了,你可以查看这个 github issue .不幸的是,对于如何处理它没有达成共识,documentation只是展示了一个使用普通 Python 类的简单用例。它与 BaseModel
和 dataclass
一起工作,直到你想要自定义验证器或其他东西,FastAPI 的作者 says :
Having a single Pydantic model for query parameters could beinterpreted as:
http://somedomain.com/?args={"k1":"v1","k2":"v2"}
or
http://somedomain.com/?k1=v1&k2=v2
or many other alternatives...
And we are not even discussing sub-models, that are valid in Pydanticmodels (and request bodies) but the behavior would be undefined fornon-body parameters (query, path, etc).
There's no obvious way to go about how it would be interpreted thatworks for all the cases (including other people's use cases, futureuse cases, etc).
So it doesn't really make sense to have it in FastAPI for a custom usecase as it's very subjective and dependent on the conventions of theteam.
jimcarreer建议使用类似的东西:
class PagingQuery(BaseModel):
page: conint(ge=1)
page_size: conint(ge=1, le=250) = 50
@classmethod
async def depends(cls, page: int = 1, page_size: int = 50):
try:
return cls(page=page, page_size=page_size)
except ValidationError as e:
errors = e.errors()
for error in errors:
error['loc'] = ['query'] + list(error['loc'])
raise HTTPException(422, detail=errors)
@app.get("/example", tags=["basic"])
def example(paging: PagingQuery = Depends(PagingQuery.depends)):
return {"page": paging.page, "page_size": paging.page_size}
但这看起来很老套,我宁愿远离它。
回答你的第二个问题,查询字符串只是一个字符串(如 'age=20&name=John'
),键值对只是字符串;您已指定 Literal
类型,因此不会进行类型转换,您会得到一个异常。
关于python - 使用 pydantic @validator 装饰器捕获错误以进行 fastapi 输入查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68556288/
我正在使用 Pydantic 为对象建模。如何使两个字段互斥? 例如,如果我有以下模型: class MyModel(pydantic.BaseModel): a: typing.Option
我正在使用 Pydantic 为对象建模。如何使两个字段互斥? 例如,如果我有以下模型: class MyModel(pydantic.BaseModel): a: typing.Option
在前面随笔《基于SqlAlchemy+Pydantic+FastApi的Python开发框架 》中介绍了框架总体的内容,其中主要的理念就是通过抽象接口的方式,实现代码的重用,提高开发效率。本
随着大环境的跨平台需求越来越多,对与开发环境和实际运行环境都有跨平台的需求,Python开发和部署上都是跨平台的,本篇随笔介绍基于SqlAlchemy+Pydantic+FastApi的Python开
下面代码来自官方FastAPI tutorials page ,我无法理解这些语句(例如,name: str)。 from typing import Optional from fastapi im
我在 Pydantic 中有一个嵌套模型。我在外部模型中有一个 root_validator 函数。我的印象是,如果调用外部根验证器,则内部模型有效。但显然不是。在下面的 MWE 中,我为内部模型提供
目前,我正在尝试为 Pandas 数据框创建一个 pydantic 模型。我想通过以下检查列是否唯一 import pandas as pd from typing import List from
我想将日期的 json 输入验证为 pydantic 类,接下来,简单地将文件注入(inject) Mongo。 带有日期类型的简单类 class CustomerBase(BaseModel):
我有以下模型 class Window(BaseModel): size: tuple[int, int] 我想像这样实例化它: fields = {'size': '1920x1080'}
我的问题很简单,令我惊讶的是到目前为止还没有人问过它: 我如何在 pydantic 中验证日期? 例如,我只想接受 1980.1.1-2000.1.1 范围内的日期。 最佳答案 validator d
是否可以为不可变 Pydantic Models 传递函数 setter ? . 例如: from uuid import uuid4, UUID from pydantic import BaseM
我正在尝试删除名字和姓氏字段以及电子邮件字段上的空格。我无法让它工作。 from pydantic import BaseModel, UUID4, SecretStr, EmailStr, cons
来自 pydantic docs我明白这一点: import pydantic class User(pydantic.BaseModel): id: int name: str cl
我试图将类中的一个字段限制为枚举。但是,当我尝试从类中获取字典时,它不会转换为字符串。相反,它保留了枚举。我查了 pydantic documentation ,但找不到与我的问题相关的任何内容。 这
我想根据特定条件动态分配字段数据类型。以下是我的模型: class Connection(BaseModel): name: str # type can be GCS or ORAC
我尝试按如下方式使用 Pydantic: from pydantic import BaseModel class A(BaseModel): prop1: str prop2: str cl
我遵循定义的 pydantic 模型。当我运行 p = IntOrStr(value=True) 时,我预计会失败,因为 True 是 bool 值,它应该会导致对 __int 和 __str cla
我遵循定义的 pydantic 模型。当我运行 p = IntOrStr(value=True) 时,我预计会失败,因为 True 是 bool 值,它应该会导致对 __int 和 __str cla
当我想使用 attr 库忽略某些字段时,我可以使用 repr=False 选项。 但是我在 pydantic 中找不到类似的选项 请看示例代码 import typing import attr fr
Pydantic 在将模型传递给另一个模型的构造函数时复制模型。这失败了: from pydantic import BaseModel class Child(BaseModel): pas
我是一名优秀的程序员,十分优秀!