gpt4 book ai didi

flask - 为什么 Flask WTForms 和 WTForms-SQLAlchemy QuerySelectField 会产生太多的值而无法解包?

转载 作者:行者123 更新时间:2023-12-03 16:16:22 24 4
gpt4 key购买 nike

我有一个非常基本的 Flask 应用程序:

from flask import Flask, render_template
from flask_wtf import FlaskForm
from wtforms_sqlalchemy.fields import QuerySelectField
from wtforms.validators import DataRequired
from flask_sqlalchemy import SQLAlchemy
from wtforms import StringField

db = SQLAlchemy()


app = Flask(__name__)
app.config['SQLALCHEMY_URI'] = 'sqlite:///:memory:'
app.config['SECRET_KEY'] = 'fnord'
db.init_app(app)


class Section(db.Model):
id = db.Column(db.Integer, primary_key = True)
name = db.Column(db.Text, nullable = False)
subject_id = db.Column(db.Integer, db.ForeignKey('subject.id'))
subject = db.relationship('Subject', back_populates='sections')


class Subject(db.Model):
id = db.Column(db.Integer, primary_key = True)
name = db.Column(db.Text, nullable = False)
sections = db.relationship('Section', back_populates='subject')


def do_something():
return Subject.query


class SelectionForm(FlaskForm):
name = StringField('Section Name', validators=[DataRequired()])
subject = QuerySelectField('Subject', query_factory=do_something, allow_blank=False, get_label='name')

with app.app_context():
db.create_all()
db.session.add(Subject(id=1, name='Science'))
db.session.add(Subject(id=2, name='Math'))
db.session.commit()

@app.route('/')
def main():
form = SelectionForm()
return render_template('index.html', form=SelectionForm())

app.run('0.0.0.0', port=5000, debug=True)

使用一个非常简单的模板:

<!DOCTYPE html>
<html>
<body>
{{ form.csrf_token }}
{{ form.name }}
{{ form.subject }}
</body>
</html>

问题是我得到 ValueError: too many values to unpack (expected 2) .这显然不是我所期望的——据我所知,我正在遵循我在网上看到的示例,但这里有些不同。问题是无论 wtforms_sqlalchemy/fields.py 文件中发生了什么,它都会得到 (<class '__main__.Subject'>, (1), None)。 ,而不是我所期望的可能是别的东西,因为它试图分配给 cls, key , 大概 (<class '__main__.Subject'>, 1) .

那么我做错了什么?

最佳答案

基于 pjcunningham 链接到的补丁,由于 wtforms 尚未发布该更新,我继续创建了我自己的 monkeypatch:

import wtforms_sqlalchemy.fields as f                                                                                                                                                                                                                                                                    
def get_pk_from_identity(obj):
cls, key = f.identity_key(instance=obj)[:2]
return ':'.join(f.text_type(x) for x in key)
f.get_pk_from_identity = get_pk_from_identity

在我的代码库中加入它就足以在他们削减一个与最新版本的 SQLAlchemy 一起工作的版本之前工作。

关于flask - 为什么 Flask WTForms 和 WTForms-SQLAlchemy QuerySelectField 会产生太多的值而无法解包?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48353190/

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