【问题标题】:How can I type hint SQLAlchemy Queries?如何键入提示 SQLAlchemy 查询?
【发布时间】:2022-01-13 03:01:32
【问题描述】:

我在 VSCode 中使用 Pylance(带有 PyRight 支持的类型提示),并具有以下功能:

def sample(session: sqlalchemy.orm.Session) -> sqlalchemy.orm.query.Query:
    return session.query((MyModel)

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

我得到这个错误的原因是有道理的,但似乎必须有某种方法可以使这个工作正常进行,否则 Pylance 只是在嘲弄我。我发现的一种解决方法(确实有效)是这样的:

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

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

【问题讨论】:

标签: python types sqlalchemy typing pylance


【解决方案1】:
def sample(session: sqlalchemy.orm.Session) -> 
"sqlalchemy.orm.query.Query[MyModel]":
    return session.query(MyModel)

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

【讨论】:

    猜你喜欢
    • 2019-08-17
    • 1970-01-01
    • 2017-08-28
    • 1970-01-01
    • 2014-04-21
    • 2012-05-15
    • 1970-01-01
    • 2021-12-27
    • 2017-04-05
    相关资源
    最近更新 更多