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

标签 python flask serialization sqlalchemy

我有一个包含几何数据类型的 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/

相关文章:

python - 使用python从c源代码文件中提取函数代码

python - 从精巧的边缘获取边界并删除图像的背景

loops - 相当于Jinja中的此循环

python - 如果在 flask 上选中了复选框,如何获取

python - 服务器从 Flask 向多个客户端发送事件

c# - 接口(interface)中的静态

java - ObjectOutputStream 的对象如何调用 Serialized 对象的私有(private) writeObject 方法

Python 验证仅允许数字和 2 位小数

scala - 如何存储纯scala代码

python - 在 python 三元中使用 continue?