Я пробовал назначение, взятое из inte rnet для отображения данных из flask в форму hmtl. Но проблема в том, что я получаю две ошибки: - 1) Файл HTML, отображаемый в flask, не найден. 2) Таблица и столбцы SQL не разрешены.
Я пытался решить эту проблему с помощью многих решений через inte rnet. Я попробовал это на Pycharm и с помощью MariaDB Connector тестовое соединение прошло успешно. Может кто-нибудь решить это для меня?
Код flask выглядит следующим образом: -
from flask import Flask, render_template, request
from flaskext.mysql import MySQL
app = Flask(__name__)
# Database connection info
app.config['MYSQL_DATABASE_USER'] = 'root'
app.config['MYSQL_DATABASE_PASSWORD'] = ''
app.config['MYSQL_DATABASE_DB'] = 'LibraryDB'
app.config['MYSQL_DATABASE_HOST'] = 'localhost'
mysql = MySQL()
mysql.init_app(app)
conn = mysql.connect()
cursor = conn.cursor()
@app.route('/search', methods=['GET', 'POST'])
def search():
if request.method == "POST":
book = request.form['book']
# search by author or book
cursor.execute("SELECT name, author from book WHERE name LIKE %s OR author LIKE %s", (book,book))
conn.commit()
data = cursor.fetchall()
# all in the search box will return all the tuples
if len(data) == 0 and book == 'all':
cursor.execute("SELECT name, author from Book")
conn.commit()
data = cursor.fetchall()
return render_template('search.html', data=data)
return render_template('search.html')
if __name__ == '__main__':
app.debug = True
app.run()
Мой HTML код выглядит следующим образом: -
<!DOCTYPE html>
<html lang="utf-8">
<head>
<link rel="stylesheet" href="../static/index.css" type="text/css">
<title>Search</title>
</head>
<body>
<h1 style="text-align: center;">Library</h1>
<form class="example" method="post" action=""
style="margin:auto;max-width:600px">
<label>
<input type="text" placeholder="Search by author or book, or all to see all the data" name="book">
</label>
<button type="submit">Search<i class="fa fa-search"></i>
</button>
</form>
<p></p>
<div style="text-align: center;">
{% for item in data %}
<tr>
<td> {{item[0]}} by {{item[1]}}</td>
</tr>
{% endfor %}
</div>
</body>
</html>
Я в порядке с CSS, так что давайте не будем беспокоиться об этом