在 pydantic 模型中包含非验证方法是不好的做法吗?

ccr*_*red 14 python validation design-patterns model pydantic

我正在使用 pydantic 1.3 来验证我正在编写的 API 的模型。

在继承自 pydantic.BaseModel 的类中包含任意方法是否常见/好的做法?

我需要一些与对象关联的辅助方法,我正在尝试决定是否需要“处理程序”类。这些模型正在转换为 json 并发送到我也在编写的宁静服务。

我的模型看起来像这样:

class Foo(pydantic.BaseModel):
    name: str
    bar: int
    baz: int
Run Code Online (Sandbox Code Playgroud)

做这样的事情是不是不好的做法:

class Foo(pydantic.BaseModel):
    name: str
    bar: int
    baz: int

    def add_one(self):
        self.bar += 1
Run Code Online (Sandbox Code Playgroud)

这对我来说有些道理,但我找不到任何人这样做的例子。

先感谢您。

SCo*_*vin 14

是的,没关系。我们可能应该记录下来。

唯一的问题是当你有一个与方法冲突的字段名称时,但如果你知道你的数据是什么样的,这不是问题。此外,您的代码可能会过度面向对象,但您还有很长的路要走。

  • 谢谢。我真的很欣赏 pydantic 的优秀文档。保持良好的工作。 (8认同)