- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在构建一个包含配置文件管理页面的简单 CMS。在此配置文件页面上,连同其他字段,存在一个下拉列表,我使用 wtforms 扩展的 QuerySelectField 从表“parks”生成:
from wtforms.ext.sqlalchemy.fields import QuerySelectField
个人资料页面上的其余字段由“用户”表填充。
假设用户已经登录,并且他们在“用户”表中的记录已经填充。 “user”表中的字段是“parks”表中值的外键:“park_id”。
当登录用户导航到他们的个人资料页面时,我想在下拉列表中显示与该用户的 park_id 外键值相对应的选择。
请注意,Flask/Python 等对我来说非常是新的。此外,我正在使用 Flask-Security,下面的用户模型基于他们的示例。也许我需要与用户/公园建立另一种关系?
显示用户保存的个人资料信息,包括可能出现在下拉列表中以供编辑的信息对我来说似乎非常基础。我担心我错过了一些基本的东西。到目前为止,关于 SO 和其他地方的其他类似问题/答案似乎让我非常困惑。
我的用户模型:
# Define models
roles_users = db.Table('roles_users',
db.Column('user_id', db.Integer(), db.ForeignKey('user.id')),
db.Column('role_id', db.Integer(), db.ForeignKey('role.id')))
class Role(db.Model, RoleMixin):
id = db.Column(db.Integer(), primary_key=True)
name = db.Column(db.String(80), unique=True)
description = db.Column(db.String(255))
class User(db.Model, UserMixin):
id = db.Column(db.Integer, primary_key=True)
email = db.Column(db.String(255), unique=True)
password = db.Column(db.String(255))
active = db.Column(db.Boolean())
confirmed_at = db.Column(db.DateTime())
roles = db.relationship('Role', secondary=roles_users,
backref=db.backref('users', lazy='dynamic'))
park_id = db.Column(db.Integer)
weather_zip = db.Column(db.String(255))
flickr_api_key = db.Column(db.String(255))
flickr_api_secret = db.Column(db.String(255))
flickr_user_id = db.Column(db.String(255))
flickr_photo_set_id = db.Column(db.String(255))
我的公园模型:
class Parks(db.Model):
id = db.Column(db.Integer, primary_key=True)
park = db.Column(db.String(255))
我的个人资料表格(带有 query_factory 的东西)
def get_parks():
return Parks.query
class ProfileForm(Form):
id = HiddenField()
email = HiddenField()
park_id = QuerySelectField('Park',[validators.InputRequired(u'Please select a park')], default=19, query_factory=get_parks, get_label='park', allow_blank=True)
weather_zip = StringField('Zip Code',[validators.Length(min=5, max=5, message=u'Zip must contain 5 numbers'), validators.InputRequired(u'please enter a 5-digit zip code')])
flickr_api_key = StringField('Flickr API Key', [validators.InputRequired(u'Please supply a Flickr API key')])
flickr_api_secret = StringField('Flickr API Secret', [validators.InputRequired(u'Please supply a Flickr API secret')])
flickr_user_id = StringField('Flickr User ID', [validators.InputRequired(u'Please supply a Flickr user id')])
flickr_set_id = StringField('Flickr Set ID', [validators.InputRequired(u'Please supply a Flickr set id')])
我的 profile_page View :
@app.route('/profile/<id>', methods=["GET","POST"])
@login_required
def profile_page(id):
id = id
current_user = User.query.filter_by(id=id).first()
form = ProfileForm(obj=current_user)
return render_template("profile.html", form=form)
我的模板的形式:
{% from "_formhelpers.html" import render_field %}
<form method=post action="/profile">
<dl>
{{ form.id(value=current_user.id) }}
{{ form.email(value=current_user.email) }}
{{ render_field(form.park_id) }}
{{ render_field(form.weather_zip) }}
{{ render_field(form.flickr_api_key) }}
{{ render_field(form.flickr_api_secret) }}
{{ render_field(form.flickr_user_id) }}
{{ render_field(form.flickr_set_id) }}
</dl>
<p><input type=submit value=Register>
</form>
渲染字段的宏(可能相关?):
{% macro render_field(field) %}
<dt>{{ field.label }}
<dd>{{ field(**kwargs) |safe }}
{% if field.errors %}
<ul class=errors>
{% for error in field.errors %}
<li>{{ error }}</li>
{% endfor %}
</ul>
{% endif %}
</dd>
{% endmacro %}
感谢您对所有这一切的帮助。
最佳答案
在喝了几杯啤酒并在这篇文章中担任主角后:SQLAlchemy/WTForms: set default selected value for QuerySelectField直到我的眼睛交叉,我发现我需要将一个结果对象从查询传递到我的 parks 表,该表由当前用户的 id 过滤。
一个特殊的细节是,我必须从当前用户的查询结果中手动分配每个字段值(除了 QuerySelectField、parks)。这是因为,在我的例子中,简单地将 current_user 结果传递给“obj=”arg 会覆盖我的 QuerySelectField 关键字(在我的例子中是“park_id”),因为“obj=current_user”赋值已经包含它自己的 park_id 参数实例,尽管无法在我的下拉列表中显示默认选择。
所以...解决方法是按如下方式更新我的 profile_page View 函数:
@app.route('/profile/<id>', methods=["GET","POST"])
@login_required
def profile_page(id):
id = id
current_user = User.query.filter_by(id=id).first()
park = Parks.query.filter_by(id=current_user.park_id).first()
form = ProfileForm(park_id=park, # this is the main thing
weather_zip=current_user.weather_zip,
flickr_api_key=current_user.flickr_api_key,
flickr_api_secret=current_user.flickr_api_secret,
flickr_user_id=current_user.flickr_user_id,
flickr_photo_set_id=current_user.flickr_photo_set_id)
return render_template("profile.html", form=form)
关于python - Flask/WTForms/QuerySelectField - 使用基于现有数据库值选择的选项呈现 QuerySelectField,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36851172/
我正在遵循Flask-potion教程并尝试保护我的api。我一直试图找出如何在User端点上设置权限,以使一个User无法查看另一个User的记录。这是我的代码: class UserResourc
项目设置 Python 3.5.3 flask 0.12.2 目录 . ├── Core │ ├── BackgroundProcessManager.py │ ├── FirebaseDat
我正在构建 flask 应用程序并决定这次尝试应用程序工厂方法,但是遇到了 flask 迁移的麻烦并且无法找出简单的解决方案。 请注意,我想将配置位置作为选项传递给脚本 管理.py: manager
我尝试通过以下示例代码来熟悉Flask-APScheduler插件:https://github.com/viniciuschiele/flask-apscheduler/blob/master/ex
我一周前刚刚了解了 Flask 和 JWT,所以我真的需要一些帮助。有人可以解释一下flask-jwt和flask-jwt-extended之间的区别吗? 最佳答案 Flask-JWT 没有那么多功能
我是 Flask 的新手,我只是想用它创建一个简单的市场。我的网站上有三种类型的用户 [卖家、买家、管理员]。我认为每种类型的用户都应该有自己的注册和登录,因为他们的角色应该提供不同类型的信息。另一方
基本上,我想做一些非常简单的事情:我想创建一个用于删除数据库中条目的表单。 模板正在创建一个包含所有条目的html表,没有任何麻烦。我现在的问题是:如何将其转换为每行都有链接的表单。 当然,我可以通过
我对Flask来说非常陌生,其中一个基本要求是我需要SEO友好的URL。 我说一条路线 @app.route('/sales/') @app.route(/sales/) def get_sales(
一直在为用户管理系统开发Flask-user,但是我看不到自定义登录页面和注册页面的方法。我使用pip安装了flask-user pip install flask-user 任何帮助,将不胜感激 最
我有一个奇怪的情况,不知道如何找到问题。 我已经创建了一个这样的蓝图 reportjobsmod = Blueprint('jobreports', __name__, url_prefix='/jo
我认为在 Flask 中拥有实例变量的正确方法是添加用户和 session ,但我正在尝试测试一个概念,我还不想经历所有这些。我试图让一个网络应用程序将图像加载到一个变量中,然后可以对其执行不同的图像
select = SelectField("City") form.select.choices = [(places['name'], places['name']) for places in p
这个问题在这里已经有了答案: Provide extra information to Flask's app.logger (2 个回答) 3年前关闭。 我正在运行一个 flask 应用程序。我想写
我当时正在编程一个非常不错的api,使用json从游戏服务器到我的网站空间获取一些json数据, 但是每次我使用angular发送请求时,我都会得到以下信息:127.0.0.1--[20 / Mar
我已经开发了一个上传表单,以将特定的.xlsx文件作为上传。要求是要处理非xlsx上载的任何异常(例如zip,exe文件)。我正在使用pyexcel库读取上传内容。我尝试创建以下代码来处理此异常: e
我使用此功能在网站上捕获404错误: @app.errorhandler(404) def page_not_found(e): logger.warning('User raised an
我正在尝试同时使用 Flask Restful 和 Flask SocketIO。我已经制作了一个 Flask Restful 应用程序,但现在我想使用 Flask SocketIO 在客户端和我的服
我有一些 Flask 应用程序,我通过设置 FLASK_APP 来运行它们。环境变量和调用 flask run .自 FLASK_DEBUG也设置了,每当我更改一些代码时,应用程序都可以方便地重新加载
我目前正在使用 Flask 构建一个应用程序。我正在努力访问 Flask 实例“app”以及 Flask-mail 实例“mail”。 下面是我的项目的样子: └── my-project ├
Remember-me是 parameter flask_login.login_user(user, remember=False, duration=None, force=False, fres
我是一名优秀的程序员,十分优秀!