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>
相关推荐
bubusa~>_<8 分钟前
解决npm install 出现error,比如:ERR_SSL_CIPHER_OPERATION_FAILED
前端·npm·node.js
学长学姐我该怎么办13 分钟前
年前集训总结python
python
量化投资技术20 分钟前
【量化科普】Sharpe Ratio,夏普比率
python·量化交易·量化·量化投资·qmt·miniqmt
yanglamei196222 分钟前
基于Python+Django+Vue的旅游景区推荐系统系统设计与实现源代码+数据库+使用说明
vue.js·python·django
虚假程序设计25 分钟前
python用 PythonNet 从 Python 调用 WPF 类库 UI 用XAML
python·ui·wpf
流烟默1 小时前
vue和微信小程序处理markdown格式数据
前端·vue.js·微信小程序
胡桃不是夹子1 小时前
CPU安装pytorch(别点进来)
人工智能·pytorch·python
梨落秋溪、1 小时前
输入框元素覆盖冲突
java·服务器·前端
小突突突1 小时前
模拟实现Java中的计时器
java·开发语言·后端·java-ee
web137656076431 小时前
Scala的宝藏库:探索常用的第三方库及其应用
开发语言·后端·scala