Flask显示数据库
Flask 是一个轻量级的 Python Web 框架,它提供了简单易用的工具和库来帮助开发人员构建 Web 应用程序,本文将详细介绍如何使用 Flask 将 Python 程序中的数据库内容显示到 HTML 页面上。
一、安装 Flask 和相关依赖
我们需要安装 Flask 框架,通过以下命令可以使用 pip 安装 Flask:
pip install flask
如果你使用 SQLite 数据库,还需要安装 sqlite3:
pip install sqlite3
对于其他数据库如 MySQL,需要安装相应的 Python 包,pymysql:
pip install pymysql
二、配置 Flask 应用程序与数据库连接
在开始之前,我们需要创建一个 Flask 应用并初始化一个数据库连接,在这个示例中,我们将使用 SQLite 数据库。
from flask import Flask import sqlite3 app = Flask(__name__) db_path = "example.db" def get_db(): conn = sqlite3.connect(db_path) return conn
三、创建数据库模型和数据表
我们定义一个数据库模型并创建对应的数据表,这里以一个简单的用户表为例:
def init_db(): with app.app_context(): db = get_db() cursor = db.cursor() cursor.execute(""" CREATE TABLE IF NOT EXISTS users ( id INTEGER PRIMARY KEY, name TEXT, email TEXT ) """) # 插入一些测试数据 cursor.execute("INSERT INTO users (name, email) VALUES (?, ?)", ("Alice", "alice@example.com")) cursor.execute("INSERT INTO users (name, email) VALUES (?, ?)", ("Bob", "bob@example.com")) db.commit()
四、查询数据库并在模板中显示数据
为了将数据显示到 HTML 页面上,我们可以使用 Flask 提供的模板引擎来呈现动态内容,下面是一个示例代码,它从数据库中检索所有用户的信息,并将结果集传递给模板。
from flask import render_template @app.route('/') def index(): db = get_db() cursor = db.cursor() cursor.execute("SELECT * FROM users") users = cursor.fetchall() return render_template('index.html', users=users)
五、创建 HTML 模板
创建一个名为index.html
的 HTML 模板文件,用于展示数据,在 Flask 中,可以使用 Jinja2 模板引擎来创建动态的 HTML 模板。
<!DOCTYPE html> <html> <head> <title>Database Content</title> </head> <body> <table> <tr> <th>ID</th> <th>Name</th> <th>Email</th> </tr> {% for user in users %} <tr> <td>{{ user[0] }}</td> <td>{{ user[1] }}</td> <td>{{ user[2] }}</td> </tr> {% endfor %} </table> </body> </html>
六、运行 Flask 应用程序
我们可以运行 Flask 应用程序,在终端中执行以下命令即可启动应用程序:
python app.py
Flask 将会监听默认端口 5000,并在浏览器中显示我们创建的 HTML 模板,页面将会显示从数据库中获取到的数据。
相关问题与解答
问题1: 如何在 Flask 中使用 Flask-SQLAlchemy 显示 SQL 查询?
答案: Flask-SQLAlchemy 是一个为 Flask 框架提供的 SQLAlchemy 扩展,它简化了在 Flask 应用程序中使用 SQLAlchemy 进行数据库操作的过程,以下是一个简单的示例:
1、安装 Flask-SQLAlchemy:
pip install flask-sqlalchemy
2、配置数据库连接:
from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///mydb.sqlite' db = SQLAlchemy(app)
3、定义数据库模型:
class User(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(80)) email = db.Column(db.String(120))
4、启用调试模式以显示 SQL 查询:
app.config['SQLALCHEMY_ECHO'] = True
5、在路由中执行查询:
@app.route('/') def index(): users = db.session.query(User).all() return render_template('index.html', users=users)
6、创建 HTML 模板:
<!DOCTYPE html> <html> <head> <title>Database Content</title> </head> <body> <table> <tr> <th>ID</th> <th>Name</th> <th>Email</th> </tr> {% for user in users %} <tr> <td>{{ user.id }}</td> <td>{{ user.name }}</td> <td>{{ user.email }}</td> </tr> {% endfor %} </table> </body> </html>
7、运行应用程序:
python app.py
访问 [http://localhost:5000](http://localhost:5000),可以看到生成的 SQL 查询语句和参数输出到控制台上,这对于调试和性能优化非常有用。
问题2: 如何在 Flask 中使用 MySQL 数据库?
答案: 要在 Flask 中使用 MySQL 数据库,可以使用 pymysql 或 SQLAlchemy(结合 Flask-SQLAlchemy),下面是使用 pymysql 的示例:
1、安装 pymysql:
pip install pymysql
2、配置数据库连接:
import pymysql.cursors from flask import Flask, g, render_template, request app = Flask(__name__) DATABASE = {"host": "localhost", "user": "root", "password": "fxl395126", "database": "nba"} def get_db(): if not hasattr(g, 'mysql_db'): g.mysql_db = pymysql.connect(**DATABASE, charset='utf8', cursorclass=pymysql.cursors.DictCursor) return g.mysql_db
3、定义路由和查询函数:
@app.route('/') def index(): db = get_db() cursor = db.cursor() cursor.execute("SELECT * FROM news") items = cursor.fetchall() return render_template('index.html', items=items)
4、创建 HTML 模板:
<!DOCTYPE html> <html lang="en"> <head> <title>Title</title> <script src="/static/jquery-2.1.4.min.js"></script> <link rel="stylesheet" href="/static/bootstrap-3.3.7-dist/css/bootstrap.min.css"> <script src="/static/bootstrap-3.3.7-dist/js/bootstrap.min.js"></script> <style> .container{width:80%;} </style> </head> <body> <div class="container"> <h2>篮球新闻</h2> <div class="row search"> <div class="col-lg-6"> <form action="/"> <input type="text" class="form-control" name="keyword" placeholder="关键词"> <input class="btn btn-default" type="submit"/> </form> </div> </div> <table class="table table-striped"> <thead> <tr>标题</tr> </thead> <tbody> {% for item in items %}<tr><td>{{ item["title"] }}</td></tr>{% endfor %} </tbody> </table> </div> </body> </html>
5、运行应用程序:
python app.py
小伙伴们,上文介绍了“flask显示数据库”的内容,你了解清楚吗?希望对你有所帮助,任何问题可以给我留言,让我们下期再见吧。
原创文章,作者:K-seo,如若转载,请注明出处:https://www.kdun.cn/ask/728783.html