我有一个包含几何数据类型的 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)
这正是我要找的。p>
关于python - 使用 flask 棉花糖序列化几何,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58299923/