tad*_*123 5 python request flask
完成这个网站所需的一切就是让它从输入中获取n和s值。但是request.get.args每次执行时都返回 None 这是代码:
my_website.py:
import sqlite3
from flask import Flask,render_template, url_for, redirect, request
app = Flask(__name__)
conn = sqlite3.connect('shoes.db', check_same_thread=False)
c = conn.cursor()
@app.route("/", methods=["GET", "POST"])
def main():
if request.method == 'GET':
return render_template('main.html')
elif request.method == 'POST':
return redirect(url_for('search'))
@app.route("/search/", methods=["GET", "POST"])
def search():
if not request.args.get("n"):
raise RuntimeError("missing n")
if not request.args.get("s"):
raise RuntimeError("missing s")
name = request.args.get('n')
size = request.args.get('s')
c.execute("SELECT * FROM shoes WHERE name LIKE ? AND sizes LIKE ? ORDER BY price",
('%'+name+'%','%'+size+'%'))
p = c.fetchall()
url = [p[i][0] for i in range(len(p))]
names = [p[i][1] for i in range(len(p))]
prices = [p[i][2] for i in range(len(p))]
sizes = [p[i][3] for i in range(len(p))]
shoe_type = [p[i][4] for i in range(len(p))]
return render_template('search.html' , url=url, names=names, prices=prices,
sizes=sizes, shoe_type=shoe_type)
if __name__ == '__main__':
app.run(debug=True)
Run Code Online (Sandbox Code Playgroud)
main.html:
{% extends "layout.html" %}
{% block content %}
<form action = "{{ url_for('main') }}" class="form" method = "POST" >
<div>
<h1>Soccer Shoes Finder</h1>
<div class="line-separator"></div>
<div>
<div class="container-fluid">
<input name = "n" type="text" placeholder="Name"/>
<input name = "s" type="text" placeholder="Size"/>
<button class="glyphicon glyphicon-search" aria-hidden="true"></button>
</div>
</div>
</form>
{% endblock %}
Run Code Online (Sandbox Code Playgroud)
这是我得到的错误:
RuntimeError: missing n
Run Code Online (Sandbox Code Playgroud)
任何意见,将不胜感激。谢谢。
request.args保存查询字符串中的值。另一方面,您的表单正在 POST 正文中发送值。
请改用request.form映射,或使用request.values,它结合了request.form和request.args。
或者,更改您的表单method,GET让浏览器将参数放入查询字符串中。
| 归档时间: |
|
| 查看次数: |
9817 次 |
| 最近记录: |