一、Flask框架入门
Flask框架是一个Python Web应用程序开发框架,它可以让开发者轻松地创建Web应用和RESTful API。Flask框架非常简洁和灵活,可以根据项目需求,选择不同的插件和扩展功能。
Flask的基本语法如下:
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello_world():
return 'Hello, World!'
上面的代码创建了一个名为app的Flask对象,并使用@app.route(‘/’)装饰器将hello_world()函数注册为Web应用的默认路由。当用户在浏览器中访问http://localhost:5000/时,将会调用hello_world()函数,并返回”Hello, World!”这个字符串。
除了@app.route(‘/’)装饰器,Flask还提供了很多其他装饰器,例如@app.route(‘/user/:id’),表示带有参数的路由。还有@app.before_request和@app.after_request两个装饰器,可以在请求前后执行相应的操作。
二、SQLite数据库操作
Flask使用SQLite作为默认的数据存储引擎,可以方便地进行数据库操作。SQLite是一种轻量级数据库引擎,不需要安装额外的数据库软件,可以直接使用Python内置的sqlite3模块操作SQLite数据库。
下面是一个使用SQLite数据库的示例:
import sqlite3
def connect_db():
conn = sqlite3.connect('my_database.db')
return conn
def query_db(query, args=(), one=False):
conn = connect_db()
cur = conn.execute(query, args)
rv = cur.fetchall()
cur.close()
conn.close()
return (rv[0] if rv else None) if one else rv
@app.route('/user/:id')
def get_user(id):
user = query_db('select * from users where id = ?', [id], one=True)
return 'User: %s' % user['username']
上述代码中,connect_db()函数创建了一个名为my_database.db的SQLite数据库文件,并返回一个数据库连接对象。query_db()函数封装了对SQLite数据库的查询操作,可以执行任意的SQL查询语句,并返回查询结果。get_user()函数使用query_db()函数查询指定用户的信息,并将结果返回给用户。
三、模板引擎Jinja2
Flask使用Jinja2作为默认的模板引擎,可以方便地进行HTML页面渲染和数据展示。Jinja2是一种灵活的模板引擎,支持模板继承、过滤器和变量等多种扩展功能。
下面是一个使用Jinja2模板引擎的示例:
from flask import render_template
@app.route('/user/:id')
def get_user(id):
user = query_db('select * from users where id = ?', [id], one=True)
return render_template('user.html', user=user)
上述代码中,get_user()函数查询指定用户的信息后,使用render_template()函数加载名为user.html的Jinja2模板文件,并将查询结果传递给模板中的user变量,用于页面展示。
user.html模板文件的内容如下:
<html>
<head><title>User Profile</title></head>
<body>
<h1>{{ user.username }}</h1>
<p>Email: {{ user.email }}</p>
<p>Phone: {{ user.phone }}</p>
</body>
</html>
上述代码中,使用了Jinja2模板引擎中的变量和标签,通过{{ user.username }}将用户的用户名展示在页面上,并使用<p>标签将用户的其他信息展示在页面上。
原创文章,作者:LOHJ,如若转载,请注明出处:https://www.506064.com/n/143433.html
微信扫一扫
支付宝扫一扫