通过调用模型函数将烧瓶宁静字段编组为列表

如何解决通过调用模型函数将烧瓶宁静字段编组为列表

我有一个Location模型和一个Weather模型。每个Location对象都有多个Weather对象(一对多关系)。

class Weather(db.Model):
    id = db.Column(db.Integer,primary_key=True)
    date = db.Column(db.DateTime,nullable=False)
    _temperature = db.Column(db.String(500),nullable=False)
    lat = db.Column(db.Float,nullable=False)
    lon = db.Column(db.Float,nullable=False)
    location = db.relationship('Location',backref=db.backref('weathers',lazy=True))
    __table_args__= (
        db.ForeignKeyConstraint(['lat','lon'],['location.lat','location.lon']),)
    def add_temperature(self,temperature):
        if not self._temperature:
            self._temperature = temperature
        else:
            self._temperature = self._temperature + ';' + temperature
    
    def get_temperature(self):
        return self._temperature.split(';')

_temperature对象中的Weather字段存储多个以;作为字符串: 37.7;37.1;36.7;36.3;36.0;35.6;35.2;35.1;35.9;38.1;40.3;42.4;43.8;44.9;45.6;45.7;44.9;43.0;41.7;40.7;39.8;39.1;38.4;37.9 我想整理位置对象,以便对特定位置的GET调用的响应返回Weather对象的数组:

[
    {
        "id": 1,"date": "1985-01-01","location": {
            "lat": 36.1189,"lon": -86.6892,"city": "Nashville","state": "Tennessee"
        },"temperature": [
            37.3,36.8,36.4,...
        ]
    },...
]

我尝试像这样定义marshal_with字段:

resource_fields = {
    'id': fields.Integer,'date': fields.DateTime('iso8601'),'temperature': fields.List(fields.nested(fields.Float,attribute='get_temperature')),'location': fields.nested(location_details)
}

但是我得到了"temperature":null回复。有什么方法可以在编组字段中调用Weather.get_temperature函数?我的资源定义为:

class WeatherList(Resource):
    @marshal_with(resource_fields)
    def get(self):
        args = WeatherGetParser().parse_args()
        result = Weather.query.filter_by(lat=args['lat'],lon=args['lon']).all()
        return result

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?