百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Flask 入门教程(flask详细教程)

myzbx 2025-04-09 18:29 5 浏览

目录

  1. 什么是Flask?
  2. 环境配置与安装
  3. 第一个Flask应用:Hello World
  4. 路由与视图函数
  5. 模板与Jinja2
  6. 表单处理与用户输入
  7. 数据库集成(SQLite + SQLAlchemy)
  8. 错误处理与调试
  9. 完整示例:待办事项应用
  10. 下一步学习建议

1. 什么是Flask?

  • Flask 是一个轻量级的Python Web框架,基于Werkzeug WSGI工具包和Jinja2模板引擎,适合快速开发小型到中型的Web应用。

核心特点

  • 简单易学:代码简洁,文档清晰。
  • 灵活可扩展:通过插件支持数据库、表单验证、用户认证等功能。
  • RESTful友好:天然支持构建API。
  • 开发友好:内置调试模式,支持热重载。

2. 环境配置与安装

步骤详解:

  1. 安装Python
  • 推荐使用Python 3.8+,可访问Python官网下载安装。
  • 验证安装:
python --version # 输出应为3.8+
  1. 创建虚拟环境(必做)
  • 作用:隔离项目依赖,避免版本冲突。
  • 操作
# 创建虚拟环境 
python -m venv flask_env 
# 激活虚拟环境
source flask_env/bin/activate # Linux/MacOS 
.\flask_env\Scripts\activate # Windows(PowerShell)
  1. 安装Flask
pip install Flask

3. 第一个Flask应用:Hello World

完整代码示例:

from flask import Flask
app = Flask(__name__)

@app.route('/')
def hello():
    return 'Hello World!'

if __name__ == '__main__':
    app.run(debug=True)  # 启用调试模式

运行与验证:

  1. 保存文件为 app.py。
  2. 在终端运行:
python app.py
  1. 访问 http://127.0.0.1:5000/,页面显示 "Hello World!"。

关键点解释:

  • Flask(__name__):创建应用实例,__name__用于确定资源路径。
  • @app.route('/'):装饰器将URL路径/绑定到视图函数hello。
  • debug=True:开启调试模式,修改代码后自动重启服务,并在浏览器显示错误详情。

4. 路由与视图函数

核心概念:

  • 路由:URL路径与视图函数的映射。
  • 视图函数:接收请求并返回响应(字符串、HTML、JSON等)。

动态路由示例:

@app.route('/user/')
def show_user(username):
    return f'User: {username}'

@app.route('/post/')
def show_post(post_id):
    return f'Post ID: {post_id}'

路由参数类型:

类型

说明

示例

string

默认类型(不含斜杠)

/user/

int

整数

/post/

float

浮点数

/price/

path

包含斜杠的字符串

/path/

5. 模板与Jinja2

为什么需要模板?

  • 分离逻辑与表现:将HTML与Python代码解耦。
  • 动态渲染:通过变量、循环、条件生成页面。

使用步骤:

  1. 创建模板目录
    项目根目录下新建 templates 文件夹(Flask默认查找此目录)。
  2. 编写基础模板(templates/base.html)



    {% block title %}{% endblock %}


    {% block content %}{% endblock %}

  1. 子模板继承(templates/index.html)
{% extends "base.html" %}
{% block title %}Home{% endblock %}
{% block content %}
  

{{ message }}

    {% for item in items %}
  • {{ item }}
  • {% endfor %}
{% endblock %}
  1. 视图函数渲染
from flask import render_template

@app.route('/')
def index():
    return render_template('index.html', 
                         message='Welcome!',
                         items=['Apple', 'Banana', 'Cherry'])

6. 表单处理与用户输入

安全提示:

  • 启用CSRF保护:生产环境中需使用Flask-WTF扩展,此处为简化示例。

表单处理示例:

  1. HTML表单(templates/form.html)
  1. 视图函数处理
from flask import request, redirect

@app.route('/form')
def show_form():
    return render_template('form.html')

@app.route('/submit', methods=['POST'])
def submit():
    username = request.form.get('username')
    email = request.form.get('email')
    # 此处应添加数据验证逻辑
    return redirect(f'/user/{username}')

7. 数据库集成(SQLite + SQLAlchemy)

使用Flask-SQLAlchemy简化操作:

  1. 安装扩展
pip install flask-sqlalchemy
  1. 配置数据库(app.py)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///site.db'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db = SQLAlchemy(app)
  1. 定义数据模型
class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(50), unique=True, nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)

    def __repr__(self):
        return f"User('{self.username}', '{self.email}')"
  1. 初始化数据库
# 在Python交互环境中执行
from app import db
db.create_all()
  1. CRUD操作示例
# 创建用户
new_user = User(username='john', email='john@example.com')
db.session.add(new_user)
db.session.commit()

# 查询用户
user = User.query.filter_by(username='john').first()

# 删除用户
db.session.delete(user)
db.session.commit()

8. 错误处理与调试

自定义错误页面:

@app.errorhandler(404)
def page_not_found(error):
    return render_template('404.html'), 404

调试模式的高级用法:

  • 开启调试器:浏览器中直接调试代码(仅限开发环境)。
  • 日志记录
import logging 
logging.basicConfig( 
    level=logging.DEBUG, 
    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s' )

9. 完整示例:待办事项应用(优化版)

代码结构:

todo-app/
├── app.py
├── templates/
│   ├── base.html
│   ├── index.html
│   └── 404.html
└── site.db

关键代码:

app.py

from flask import Flask, render_template, request, redirect, url_for
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///site.db'
db = SQLAlchemy(app)

class Todo(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    content = db.Column(db.String(200), nullable=False)
    completed = db.Column(db.Boolean, default=False)

@app.route('/')
def index():
    todos = Todo.query.all()
    return render_template('index.html', todos=todos)

@app.route('/add', methods=['POST'])
def add():
    content = request.form.get('content')
    if content:
        new_todo = Todo(content=content)
        db.session.add(new_todo)
        db.session.commit()
    return redirect(url_for('index'))

@app.route('/delete/')
def delete(id):
    todo = Todo.query.get_or_404(id)
    db.session.delete(todo)
    db.session.commit()
    return redirect(url_for('index'))

if __name__ == '__main__':
    with app.app_context():
        db.create_all()  # 自动创建数据库表
    app.run(debug=True)

templates/index.html

{% extends "base.html" %}
{% block title %}Todo List{% endblock %}
{% block content %}
  

Todo List

    {% for todo in todos %}
  • {% if todo.completed %}{% endif %} {{ todo.content }} {% if todo.completed %}{% endif %} Delete
  • {% endfor %}
{% endblock %}

10. 下一步学习建议

  1. 扩展功能
  • 用户认证:使用Flask-Login管理用户会话。
  • 表单验证:通过Flask-WTF添加CSRF保护和表单验证。
  • 前端增强:集成Bootstrap或JavaScript框架(如Vue.js)。
  1. 部署实践
  • 使用Gunicorn + Nginx部署到Linux服务器。
  • 尝试云平台部署(如Heroku、AWS EC2)。
  1. 深入学习
  • 阅读Flask官方文档
  • 学习REST API开发(Flask-RESTful扩展)
  • 探索大型项目结构(蓝图、工厂模式)

通过本教程,你已掌握Flask的核心功能,包括路由、模板、数据库操作和错误处理。接下来,尝试为你的应用添加更多功能,并探索Flask生态系统的强大扩展能力!

相关推荐

Django零基础速成指南:快速打造带用户系统的博客平台

#python##服务器##API##编程##学习#不是所有教程都值得你花时间!这篇实战指南将用5分钟带你解锁Django核心技能,手把手教你从零搭建一个具备用户注册登录、文章管理功能的完整...

iOS 17.0 Bootstrap 1.2.9 半越狱来啦!更新两点

这款Bootstrap半越狱工具终于更新,离上一次更新已相隔很久,现在推出1.2.9版本,主要为内置两点功能进行更新,也是提升半越狱的稳定性。如果你正在使用这款半越狱工具的,建议你更新。注意!...

iOS 16.x Bootstrap 1.2.3 发布,支持运行清理工具

本文主要讲Bootstrap半越狱工具更新相关内容。如果你是iOS16.0至16.6.1和17.0系统的,想体验半越狱的果粉,请继续往下看。--知识点科普--Bootstrap...

SpringBoot整合工作流引擎Acticiti系统,适用于ERP、OA系统

今日推荐:SpringBoot整合工作流引擎Acticiti的源码推荐理由:1、SpringBoot整合工作流引擎Acticiti系统2、实现了三级权限结构3、持久层使用了mybatis框架4、流程包...

SpringCloud自定义Bootstrap配置指南

在SpringCloud中自定义Bootstrap配置需要以下步骤,以确保在应用启动的早期阶段加载自定义配置:1.添加依赖(针对新版本SpringCloud)从SpringCloud2020...

Python使用Dash开发网页应用(三)(python网页开发教程)

PlotlyDash开发Web应用示例一个好的网页设计通常都需要编写css甚至js来定制前端内容,例如非常流行的bootstrap框架。我们既然想使用Dash来搭建web应用,很大的一个原因是不熟悉...

Oxygen XML Editor 27.1 中的新功能

OxygenXMLEditor27.1版是面向内容作者、开发者、合作者和出版商的行业领先工具包的增量版本。在27.1版本中,AIPositronAssistant得到了增强,包括用于...

【LLM-多模态】Mini-Gemini:挖掘多模态视觉语言模型的潜力

一、结论写在前面论文提出了Mini-Gemini,一个精简而强大的多模态VLM框架。Mini-Gemini的本质在于通过战略性框架设计、丰富的数据质量和扩展的功能范围,发掘VLM的潜在能力。其核心是补...

谐云课堂 | 一文详解分布式改造理论与实战

01微服务与分布式什么是分布式?首先,我们对上图提到的部分关键词进行讲解。单体,是指一个进程完成全部的后端处理;水平拆分,是同一个后端多环境部署,他们都处理相同的内容,使用反向代理来均衡负载,这种也叫...

基于Abaqus的手动挡换挡机构可靠性仿真

手动挡,也称手动变速器,英文全称为Manualtransmission,简称MT,即用手拨动换挡操纵总成才能改变变速器内的齿轮啮合位置,改变传动比,从而达到变速的目的。家用轿车主要采用软轴连接的换挡...

【pytorch】目标检测:彻底搞懂YOLOv5详解

YOLOv5是GlennJocher等人研发,它是Ultralytics公司的开源项目。YOLOv5根据参数量分为了n、s、m、l、x五种类型,其参数量依次上升,当然了其效果也是越来越好。从2020...

超实用!50个非常实用的PS快捷键命令大全分享

今天,给大家介绍50个非常实用的快捷键命令大全,大家伙都是设计师,关于软件使用那是越快越好啊。一、常用的热键组合1、图层混合模式快捷键:正常(Shift+Option+N),正片叠底(Shif...

Pohtoshop中深藏不露的小技巧(科目一考试技巧记忆口诀看完必过)

邢帅教育ps教程为大家总结了一些Pohtoshop中深藏不露的小技巧,可以帮助到大家在设计时减少不必要的麻烦,提高工作效率哦~~~1.设置网格线保持像素完美不在1:1分辨率下也能保持像素完美,可以...

Ganglia监控安装总结(监控安装工作总结)

一、ganglia简介:Ganglia是一个跨平台可扩展的,高性能计算系统下的分布式监控系统,如集群和网格。它是基于分层设计,它使用广泛的技术,如XML数据代表,便携数据传输,RRDtool用于数据...

谁说Adobe XD做不出好看的设计?那是你没搞懂这些功能

AdobeXD的美化栏具有将设计视图美化的功能,它能使界面设计和原型设计更漂亮、更吸引眼球。美化栏的7个功能包括竖线布局设计、横线布局设计、重复网格、图形大小和位置设置、响应式调整大小、文字美化以及...