在搜索期间访问 Flask-Sqlalchemy 查询中的表变量

我正在使用 Flask 和 Flask-SQLalchemy 以及 Flask-Login 编写一个 RESTful api。我有一个Users初始化的模型,如下所示:


class Users(UserMixin, db.Model):

    __tablename__ = "users"

    # STATIC Standard required info

    id = db.Column("id", db.Integer, primary_key = True)

    public_id = db.Column("public_id", db.String(50), unique = True)

    email = db.Column("email", db.String(50), unique = True)

    username = db.Column("username", db.String(20), unique = True)

    password = db.Column("password", db.String(20))


    # DYNAMIC Standard required info

    lat = db.Column("lat", db.Float)

    lon = db.Column("lon", db.Float)

表中还有其他元素,但纬度和经度最相关。我有一个方法distanceMath()可以接收当前登录用户的经纬度,以及表格中的经纬度来计算它们之间的距离。但我无法弄清楚如何在以下调用期间访问表值distanceMath而不会收到语法错误:


lat1 = current_user.lat

lon1 = current_user.lon

users = Users.query.filter(distanceMath(lat1, Users.lat, lon1, Users.lon)==1)

    output = []

    for user in users:

        data = {}

        data["username"] = user.username

        output.append(data)

    return str(output)

以防万一,distanceMath方法如下:


# Haversine Distance

def distanceMath(lat1, lat2, lon1, lon2):

    distance = math.acos(math.sin(math.radians(lat1))*math.sin(math.radians(lat2))) + math.cos(math.radians(lat1))*math.cos(math.radians(lat2))*math.cos(math.radians(lon1)-math.radians(lon2))

    return distance

错误的一个例子是:


TypeError: must be real number, not InstrumentedAttribute

在我的理解中,这基本上是在说,User.lat并且User.lon不指浮点数甚至数字,而是指表的属性。我的问题是如何实际使用 lat 和 lon 等于(在数据库中它们分别等于 37.7 和 -122.4)。


暮色呼如
浏览 177回答 2
2回答
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python