gpt4 book ai didi

python - 使用 flask 棉花糖序列化几何

转载 作者:行者123 更新时间:2023-12-05 05:08:27 25 4
gpt4 key购买 nike

我有一个包含几何数据类型的 sqlalchemy2(带有 geoalchemy 扩展)模型:

class Estate(db.Model):
id = db.Column(db.Integer, primary_key=True)
geom = db.Column(Geometry(geometry_type='POLYGON')
user_id = db.Column(db.Integer, db.ForeignKey('users.id'))
user = db.relationship('Users', backref='estates')

和棉花糖模式:

class EstateSchema(ma.ModelSchema):
class Meta:
model = Estates

但在尝试序列化期间我收到以下错误:

marshmallow_sqlalchemy.exceptions.ModelConversionError: Could not find field column of type <class 'geoalchemy2.types.Geometry'>.

ModelConversion 提示 WKBElement,因为未定义为公共(public)字段。

问题是,我如何修改代码,让(反)序列化器与几何模型字段一起工作?

最佳答案

我知道这已经很老了,但现在回答是因为我在解决这个问题后才自己解决了这个问题。我完成它的方法是像这样向我的模式添加一个方法字段:

from marshmallow_sqlalchemy import SQLAlchemySchema, fields
from geoalchemy2.shape import to_shape

from common.models import Node


class NodeSchema(SQLAlchemySchema):
class Meta:
model = Node

geom = fields.fields.Method("geomToPoint")

def geomToPoint(self, obj):
return to_shape(obj.geom)

这将返回 Geometry字段作为 Shapely 形状字段,类似于 POINT (39.2934324 -123.59348)这正是我要找的。

关于python - 使用 flask 棉花糖序列化几何,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58299923/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com