- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
尝试重现(以最简单的方式)Maciej Cegłowski 的 http://pinboard.in ;我有书籍和标签,而不是链接和标签。每本 Book
都可以用任意数量的 Tag
进行标记,并且一个 Tag
与许多 Book
相关联
class Book(db.Model):
__tablename__ = 'books'
book_id = db.Column(db.Integer, primary_key=True)
title = db.Column(db.String(120), unique=True)
auth = db.Column(db.String(120), unique=True)
comment = db.Column(db.String(120), unique=True)
date_read = db.Column(db.DateTime)
era = db.Column(db.String(36))
url = db.Column(db.String(120))
notable = db.Column(db.String(1))
tagged = db.relationship('Tag', secondary=assoc, backref=db.backref('thebooks',lazy='dynamic'))
class Tag(db.Model):
__tablename__ = 'tags'
tag_id = db.Column(db.Integer, primary_key=True)
tag_name = db.Column(db.String(120))
def construct_dict(query):
books_dict = {}
for each in query: # query is {<Book object>, <Tag object>} in the style of assoc table - therefore, must make a dictionary bc of the multiple tags per Book object
book_data = books_dict.setdefault(each[0].book_id, {'bookkey':each[0], 'tagkey':[]}) # query is a list like this {index-book_id, {<Book object>}, {<Tag object #1>, <Tag object #2>, ... }}
book_data['tagkey'].append(each[1])
return books_dict
@app.route('/query')
def query():
query = db.session.query(Book, Tag).outerjoin('tagged') # query to get all books and their tags
books_dict = construct_dict(query)
return render_template("query.html", query=query, books_dict=books_dict)
这是我开始有点迷路的地方;也就是说,构建正确的逻辑来处理我正在尝试做的事情,这将在下面详细描述。
{% for i in books_dict %}
<a href="{{books_dict[i].bookkey.url}}" target="_blank">{{books_dict[i].bookkey.title}}</a>
{% for i in books_dict[i].tagkey %} # tagkey is a list of Tag objects; for each Book's tagkey, print each Object's tag_name
<a href="/tag/{{i.tag_name}}" class="tag-link">{{i.tag_name}}</a>
{% endfor %}
<a href="" class="edit">edit</a> # eventually, edit link will display the form
<form method="add_tag_to_book">
{% for j in books_dict[i].tagkey %}
<input type="text" name="tag" value="{{j.tag_name}}" />
{% endfor %}
<input type="submit" value="save">
</form>
{% endfor %}
对于任何一本书,用户(现在只有我)应该能够:
更新
assoc
表,以便在 Book 实例和 Tag 实例之间创建一个新的关联;UPDATE
assoc
表,以便 Book 实例正确关联新标签)我认为这项任务对我来说很复杂,因为我仍在努力处理 Jinja 循环中的范围。然而,我意识到我需要做这样的事情:
获取用户的输入;检查 tag_name
是否已经存在于 __tablename__ = "tags"
如果 tag_name
已经存在,则获取其 tag_id
以及 Book 实例的 book_id
并将行添加到 assoc
表(即 book_id|tag_id)
如果tag_name
不存在,创建新的Tag()
实例,然后执行步骤2
最佳答案
首先,构建book_dict
词典:
def construct_dict(query):
books_dict = {}
for each in query: # query is {<Book object>, <Tag object>} in the style of assoc table - therefore, must make a dictionary bc of the multiple tags per Book object
book_data = books_dict.setdefault(each[0].book_id, {'bookkey':each[0], 'tagkey':[]}) # query is a list like this {index-book_id, {<Book object>}, {<Tag object #1>, <Tag object #2>, ... }}
book_data['tagkey'].append(each[1])
return books_dict
@app.route('/query')
def query():
query = db.session.query(Book, Tag).outerjoin('tagged') # query to get all books and their tags
books_dict = construct_dict(query)
return render_template("query.html", query=query, books_dict=books_dict)
然后,除了打印每个Book
book_dict
中的实例(并列出与书相关的 Tag
对象),我们为每个 Book
创建一个表单允许用户关联新 Tag
的实例用于 Book
:
{% for i in books_dict %}
<a href="{{books_dict[i].bookkey.url}}">{{books_dict[i].bookkey.title}}</a>,
{{books_dict[i].bookkey.auth}}
{% for i in books_dict[i].tagkey %}
<a href="/tag/{{i.tag_name}}" class="tag-link">{{i.tag_name}}</a>
{% endfor %}
<form action="{{ url_for('add_tag_to_book') }}" method=post class="edit-form">
<input type="hidden" name="book_id" value={{books_dict[i].bookkey.book_id}} />
<input type="text" name="tag_name" value="" />
<input type="submit" value="save">
</form>
{% endfor %}
... 可见 <input>
将采用用户输入的值,其中有 name="tag_name"
;提交表单时,路线 /add_tag_to_book
路线被称为。从表单中,我们获取 book_id
(打印在表格中但不可见,即 <input type="hidden" name="book_id" value={{books_dict[i].bookkey.book_id}} />
);我们还获取了 <input>
的值带有 name="tag_name"
的元素):
@app.route('/add_tag_to_book', methods=['POST'])
def add_tag_to_book():
b = request.form['book_id']
t = request.form['tag_name']
接下来,我们应该检查是否tag_name
用户提交的已经是一个Tag()
; Python 返回 None
如果标签名称不在 Tag
中找到 table ;否则,它将返回 Tag
具有 tag_name=t
的对象(即用户提交的tag_name
);如果tag_object == None
, 我们需要创建 Tag()
的新实例使用 tag_name
用户提供:
tag_object = Tag.query.filter_by(tag_name=t).first()
if tag_object == None:
new_tag = Tag(tag_name=t)
db.session.add(new_tag)
db.session.commit()
tag_object = Tag.query.filter_by(tag_name=t).first()
tag_object_id = tag_object.tag_id
此时,我们将有一个 tag_object
(新创建的或以前在我们的 Tag
表中)其 tag_id
我们可以抓取并插入到我们的关联表中,连同 book_id
对于 Book
目的。接下来,我们创建一个数据库连接,插入book_id
& tag_id
,提交到数据库,然后将用户返回到 query
页:
conn = db.session.connection()
ins = assoc.insert().values(book_id=b,tag_id=tag_object_id)
result = conn.execute(ins)
db.session.commit()
return redirect(url_for('query'))
将所有内容放在一起,完整的 @app.route('/add_tag_to_book')
看起来像这样:
@app.route('/add_tag_to_book', methods=['POST'])
def add_tag_to_book():
b = request.form['book_id']
t = request.form['tag_name']
tag_object = Tag.query.filter_by(tag_name=t).first()
if tag_object == None:
new_tag = Tag(tag_name=t)
db.session.add(new_tag)
db.session.commit()
tag_object = Tag.query.filter_by(tag_name=t).first()
tag_object_id = tag_object.tag_id
conn = db.session.connection()
ins = assoc.insert().values(book_id=b,tag_id=tag_object_id)
result = conn.execute(ins)
db.session.commit()
return redirect(url_for('query'))
关于python - 如何通过HTML形式插入到关联表中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42840641/
这是一个新手理论问题 - 我刚刚开始使用 Python 并研究 Django 和 orm。问题:如果我开发我的对象并通过额外的开发修改基础对象结构、继承等 - Django 的 ORM 解决方案会自动
我正在使用带有服务器端处理器的 JavaScript 表单,并且我希望能够让表单根据下拉列表转到不同的电子邮件。我已经根据其他表格尽了最大努力,但似乎无法通过电子邮件。我已在电子邮件地址的选项标签下添
一个简单的问题:给定定义,(来自 Haskell SOE) do x — el; el\ ...; en => el »= \x — do e2\ ...; en 和: do let d
我是 Angular 5 的新手。我目前正在研究 Angular Reactive 表单。我有一个下面的 JSON 结构,我需要在从 FORM 获取值后发回 REST API。 JSON 结构: {
我是 Angular 5 的新手。我目前正在研究 Angular Reactive 表单。我有一个下面的 JSON 结构,我需要在从 FORM 获取值后发回 REST API。 JSON 结构: {
我有一个类型(称之为 A),我想创建一个 A -> A、A -> A -> A、A -> A -> A -> ... 等类型的函数的类型类.这不起作用: {-# LANGUAGE FlexibleIn
我正在使用 java 线程同时管理多个 (3) 程序。1 用于 Java swing 表单(绘制 UI 以进行输入),1 用于在系统托盘上设置图标(从 UI 获取输入后立即启动),1 用于处理输入并将
在当前的元素中,我在表单中遇到了一个问题。表单中标签的字体大小可能大于默认值。如果我把它举起来,那么右边的输入必须垂直居中。 我查看了 Bootstrap 和 Foundation,但都没有解决这个问
为了好玩,我使用了一段从 friend 那里得到的代码,并尝试创建一个包含用户名和密码的登录字段,但我很难获得单词旁边的字段。 username 这个词和你输入的框之间有很大的差距。密码也是如此。 这
我的表单中有一个嵌套的控制组,我想访问它们的表单状态值(如原始和有效)以动态显示验证错误。 是这样动态构建的 controlMap['password'] = this.password; contr
发送后我试图重置我的表单,但只有值设置为空。 component.html {{note.value?.length || 0}}/10
我正在尝试自定义 Stripe 结帐表单,但我不知道如何添加输入。我想添加“电话号码”和“姓名”以创建费用和客户。你知道我该怎么做吗? 这是我应该自定义的代码。 最佳答案 您将无法使用
所以我有这个需求,我想以表格的形式提交一个由五个记录组成的表单。这就是它的样子表: 这是对应的代码: Section Q.No Question
我有一个使用 react 形式和输入文本的情况。 我需要: 当用户输入时,根据输入的内容建议一个列表(我使用的是 ngx bootstrap typeahead); 仅当用户失去输入焦点时才验证输入字
我希望重构我的 Angular 项目中的大量组件,以具有强类型的 FormGroups、FormArrays 和 FormControls。 我只是在寻找一种实现强类型 react 形式的好方法。任何
我有事件表格: 'horizontal', 'fieldConfig' => [ 'template' => "{input}\n{hint}\n{error}",
是否有关于如何实现多选和响应式表单的示例? 我正在尝试在 multiselect-dropdown 上设置所选项目(从数据库中检索),它会更新显示的项目( View ),但会引发以下错误: core.
我想在表单中添加按钮以动态添加输入。但是我发现,如果我在表单中添加了一个仅记录到控制台的按钮(并且当我尝试添加输入时),它将记录日志,然后表单中断。我的Electron应用程序的前端窗口崩溃(不退出但
我有一个这样的表格 此表单位于指令内: angular.module('crowdcoreApp').directive('investorForm',function(){
我在 angularjs Controller 中调用的 $mdDialog 中有一个表单,如下所示: actions-controller.js function callForm() {
我是一名优秀的程序员,十分优秀!