Flask小项目教程(含MySQL与前端部分)

CONTENTS

    • [1. 环境配置](#1. 环境配置)
    • [2. 快速搭建Flask应用程序](#2. 快速搭建Flask应用程序)

1. 环境配置

首先我们在项目的根目录下创建一个 Python 虚拟环境,打开命令行输入以下指令:

shell 复制代码
python -m venv venv

启动虚拟环境:

shell 复制代码
.\venv\Scripts\Activate.ps1

如果遇到报错:.\venv\Scripts\Activate.ps1 : File ...\venv\Scripts\Activate.ps1 cannot be loaded because running scripts is disabled on this system.,说明可能是系统禁止运行脚本,打开 PowerShell 查看一下系统当前的执行策略:

shell 复制代码
get-executionpolicy

如果为 Restricted 说明此系统不载入任何配置文件,不运行任何脚本。我们需要修改一下执行策略,以管理员身份打开 PowerShell,使用以下指令修改执行策略:

shell 复制代码
Set-ExecutionPolicy Unrestricted  # 设置全局的执行策略
Set-ExecutionPolicy -Scope CurrentUser Unrestricted  # 设置当前用户的执行策略

接下来我们安装 Flask:

shell 复制代码
pip install flask

2. 快速搭建Flask应用程序

我们先看一下如何创建 URL 与函数的对应关系:

py 复制代码
from flask import Flask

app = Flask(__name__)  # 实例化Flask类的对象

@app.route("/index")
def index():
    return "<h1>Hello World!</h1>"

if __name__ == "__main__":
    app.run()

其中的 @app.route 作用是创建了网址 /indexindex 函数的对应关系。现在我们运行程序,能看到终端的输出: * Running on http://127.0.0.1:5000,然后我们访问 http://127.0.0.1:5000/index 即可看到 Hello World!

注意我们返回的字符串中有 <h1></h1> 标签,这是 HTML 标签,整个项目的逻辑是用户(浏览器)访问 URL 时向 Web 应用(此处就是 Flask)发送请求,然后 Web 应用向浏览器返回一个字符串,浏览器是具备解析 <h1> 这类 HTML 标签的能力的。前端部分的学习可以在 Web 专栏中找到。

Tips:PyCharm 输入 main 即可自动补全出 if __name__ == "__main__":,VS Code 则需要进行配置,点击左下角的齿轮,选择 User Snippets(用户代码片段),然后在弹出的下拉选框中选择 python,这时会出来一个配置文件 python.json,然后向该文件中添加 "Print to console" 项,修改后如下:

json 复制代码
{
	"Print to console": {
		"prefix": "main",
		"body": [
			"if __name__ == '__main__':",
			"    ${1:pass}",
			"",
		],
		"description": "python--main"
	}
}

Flask 框架为了让我们写 HTML 标签更方便,支持将这些内容写到一个单独的文件中,render_template 函数可以渲染 HTML 文件,默认是从项目根目录下的 templates 目录中开始寻找文件,我们创建 templates 目录并创建一个 index.html 如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Index</title>
</head>
<body>
    <h1>Hello World!</h1>
</body>
</html>

现在就可以将之前的字符串改为渲染一个 HTML 文件了:

py 复制代码
from flask import Flask, render_template

app = Flask(__name__)  # 实例化Flask类的对象

@app.route("/index")
def index():
    return render_template("index.html")

if __name__ == "__main__":
    app.run()

假设我们在页面中需要引入一张本地的图片,在 Flask 中要求我们需要将图片这类静态文件(还有视频、音频、CSS、JS 等)放在项目根目录中的 static 目录下,假设我们有一张图片放在 static/image 目录下,那么就可以直接用相对路径调用该图片了:

html 复制代码
<!DOCTYPE html>
<html lang="en">
...
<body>
    <h1>Hello World!</h1>
    <img src="/static/image/background.jpg" />
</body>
</html>
相关推荐
zmzb01033 小时前
Python课后习题训练记录Day130
开发语言·python
码不停蹄的玄黓3 小时前
Spring Bean 生命周期
java·后端·spring
西安邮电大学4 小时前
分治算法详细讲解
java·后端·其他·算法·面试
老马聊技术4 小时前
AI对话功能之SpringBoot整合Vue3
vue.js·人工智能·spring boot·后端
甲维斯4 小时前
测一波Kimi K2.7,消耗一周配额!
前端·人工智能·游戏开发
Dick5074 小时前
ROS2 多机器人通用 Driver 层复盘:BaseRobotDriver 到多平台 Mock 切换实现
前端·javascript·机器人
左直拳4 小时前
mysql分区表自动归档
mysql·分区表·分区表归档
高洁014 小时前
医疗行业的数字孪生革命
python·机器学习·数据挖掘·transformer·知识图谱
MATLAB代码顾问4 小时前
Python Pandas数据分析入门指南
python·数据分析·pandas
武子康4 小时前
调查研究-174 什么是“红丸主义“:它为什么吸引人,又为什么容易把人带偏?
后端