如何键入 SQLAlchemy 查询提示?

T. *_*nus 5 python types sqlalchemy typing pylance

我在 VSCode 中使用 Pylance(由 PyRight 提供类型提示),并具有以下功能:

def sample(session: sqlalchemy.orm.Session) -> sqlalchemy.orm.query.Query:
    return session.query((MyModel)
Run Code Online (Sandbox Code Playgroud)

当查看 Pylance 的类型推断时,该函数实际上具有 Query[Unknown] 的返回类型。当我将类型提示更改为 时sqlalchemy.orm.query.Query[MyModel],Pylance 可以正确推断出它的相关类型。这很棒!直到我实际运行代码并得到TypeError: 'type' object is not subscriptable.

我得到这个错误的原因是有道理的,但似乎必须有某种方法来实现这个工作,否则皮兰斯只是在嘲笑我。我发现的一种解决方法(确实有效)是这样的:

def sample(session: sqlalchemy.orm.Session) -> (
    sqlalchemy.orm.query.Query[MyModel]
    if typing.TYPE_CHECKING
    else sqlalchemy.orm.query.Query
):
    return session.query(MyModel)
Run Code Online (Sandbox Code Playgroud)

但这显然很糟糕,我讨厌它。我也许可以制作一个辅助函数来提取它并且更具可读性,但我真的觉得这应该是可能的,而不需要一个糟糕的解决方法!

T. *_*nus 7

def sample(session: sqlalchemy.orm.Session) -> 
"sqlalchemy.orm.query.Query[MyModel]":
    return session.query(MyModel)
Run Code Online (Sandbox Code Playgroud)

实际上工作得很好,但我觉得很愚蠢。如果还有其他方法,我很乐意接受这个答案!