一、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>标签将用户的其他信息展示在页面上。