python - Flask peewee AttributeError:“ModelSelect”对象没有属性“_meta”
问题描述
我在 pipenv 烧瓶环境中有一个非常简单的设置、一个模型和 api 文件。我目前正在使用 peewee 并且一直面临从数据表中获取所有结果的问题。我以前在 python 中做过这个并且工作正常但是不确定在 Flask 中我做错了什么。这是我的模型
from peewee import *
import peewee as pw
db = pw.MySQLDatabase('xxxxx', host="localhost", port=3306, user='xxx',
password="xxxxx")
class HomeCarousel(Model):
icon = pw.CharField(100)
header = pw.CharField(50)
text = pw.CharField(100)
class Meta:
database = db
这是我的api文件
from flask import Flask, g
from flask import jsonify, make_response
from playhouse.shortcuts import model_to_dict
from peewee import *
import peewee as pw
from models import *
from flask_cors import CORS
app = Flask(__name__)
cors = CORS(app, resources={r"/*": {"origins": "*"}})
@app.route('/')
def index():
items = HomeCarousel.select()
items = model_to_dict(items)
return items
if __name__ == '__main__':
app.run()
现在的问题是,当我这样做时,items = HomeCarousel.select()
我得到一个错误“AttributeError:'ModelSelect'对象没有属性'_meta'”
如果我只选择一条记录,一切正常。 items = HomeCarousel.get()
有谁知道我在这里做错了什么?
谢谢
解决方案
model_to_dict 需要一个对象实例。您正在向它传递一个ModelSelect。您需要遍历 ModelSelect 中返回的对象:
@app.route('/')
def index():
items = HomeCarousel.select()
items = [model_to_dict(item) for item in items]
return items
推荐阅读
- java - 我的 Jar 文件无法打开,我解决问题的动力正在消亡
- angular - Angular 6 单元测试:以反应形式改变原始状态
- c - 为什么我可以在函数之后返回 `int` 而不是 `char *`?
- javascript - 为什么这个 `Promise.all()` 语句不等待承诺解决?
- c# - 无法将类型 '(string, int USD) 隐式转换为 'string'
- java - 图标对象对角线飞出框架
- ruby-on-rails - pg_search_scope 不按 desc 或 asc 排序
- sbt-native-packager - 是否有与 sbt-pack packMain 等效的 sbt-native-packager 选项?
- javascript - AJAX 响应未分配给变量
- r - 根据列表中的限制切割间隔