一篇文章入门Python Flask框架前后端数据库开发实践(pycharm在anaconda环境下)

Python Flask 是一个轻量级的 Web 应用框架,也被称为微框架。它以简洁、灵活和易于上手的特点而受到开发者的喜爱。

核心特点
轻量级:Flask 核心代码简洁,仅包含 Web 开发的基本功能,不强制使用特定的数据库、模板引擎等,开发者可按需选择适合的扩展。
灵活性高:可以自由选择使用的数据库(如 MySQL、SQLite)、模板引擎(如 Jinja2)和其他工具,方便根据项目需求进行定制。
易于上手:对于初学者而言,Flask 的文档清晰易懂,代码结构简单,能够快速搭建起一个 Web 应用。
基本组件
路由系统:用于将 URL 映射到对应的 Python 函数,当用户访问特定 URL 时,执行相应的函数并返回结果。
请求和响应对象:在处理 Web 请求时,Flask 提供了request对象用于获取客户端发送的请求信息,如表单数据、URL 参数等;同时,使用response对象返回响应内容给客户端。
模板引擎:默认使用 Jinja2 作为模板引擎,它允许将 Python 代码和 HTML 模板结合,方便生成动态的 HTML 页面。
会话管理:支持会话(session)管理,通过会话可以在多个请求之间保存用户的状态信息,如用户登录状态。

1、创建新的anaconda环境

 conda create --name todoenv python=3.10

创建了todoenv这个conda环境,我们查看一下有已有的环境

conda env list

二、创建项目文件

项目结构如下:

todoapp/
├── app/
│   ├── __init__.py
│   ├── models.py
│   ├── routes.py
│   ├── templates/
│   │   ├── base.html
│   │   ├── index.html
│   │   └── edit.html
│   └── static/
│       └── style.css
├── config.py
├── requirements.txt
└── run.py

安装依赖:requirements.txt,通过 pip install -r requirements.txt 一键安装依赖

Flask==3.0.2
Flask-SQLAlchemy==3.1.1
Flask-Migrate==4.0.5
python-dotenv==1.0.1

配置文件:config.py

import os
from dotenv import load_dotenvbasedir = os.path.abspath(os.path.dirname(__file__))
load_dotenv(os.path.join(basedir, '.env'))class Config:SECRET_KEY = os.environ.get('SECRET_KEY') or 'your-secret-key-here'SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL') or \'sqlite:///' + os.path.join(basedir, 'app.db')SQLALCHEMY_TRACK_MODIFICATIONS = False

应用工厂:app/__init.py__

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate
from config import Configdb = SQLAlchemy()
migrate = Migrate()def create_app(config_class=Config):app = Flask(__name__)app.config.from_object(config_class)db.init_app(app)migrate.init_app(app, db)from app.routes import bpapp.register_blueprint(bp)return app

数据模型(Model):app/models.py

from datetime import datetime
from app import dbclass Todo(db.Model):id = db.Column(db.Integer, primary_key=True)title = db.Column(db.String(100), nullable=False)description = db.Column(db.String(200))completed = db.Column(db.Boolean, default=False)created_at = db.Column(db.DateTime, default=datetime.utcnow)def __repr__(self):return f'<Todo {self.title}>'

路由和视图(Controller):app/routes.py

from flask import Blueprint, render_template, request, redirect, url_for, jsonify
from app.models import Todo
from app import dbbp = Blueprint('main', __name__)@bp.route('/', methods=['GET', 'POST'])
def index():if request.method == 'POST':title = request.form['title']description = request.form['description']new_todo = Todo(title=title, description=description)db.session.add(new_todo)db.session.commit()return redirect(url_for('main.index'))todos = Todo.query.order_by(Todo.created_at.desc()).all()return render_template('index.html', todos=todos)@bp.route('/edit/<int:id>', methods=['GET', 'POST'])
def edit(id):todo = Todo.query.get_or_404(id)if request.method == 'POST':todo.title = request.form['title']todo.description = request.form['description']todo.completed = 'completed' in request.formdb.session.commit()return redirect(url_for('main.index'))return render_template('edit.html', todo=todo)@bp.route('/delete/<int:id>')
def delete(id):todo = Todo.query.get_or_404(id)db.session.delete(todo)db.session.commit()return redirect(url_for('main.index'))# API 端点示例
@bp.route('/api/todos', methods=['GET'])
def get_todos():todos = Todo.query.all()return jsonify([{'id': todo.id,'title': todo.title,'description': todo.description,'completed': todo.completed} for todo in todos])

编辑模板:app/templates/edit.htm
 

{% extends "base.html" %}{% block content %}<h1 class="mb-4">Edit Todo</h1><form method="POST"><div class="mb-3"><label class="form-label">Title</label><input type="text" class="form-control" name="title" value="{{ todo.title }}" required></div><div class="mb-3"><label class="form-label">Description</label><textarea class="form-control" name="description" rows="3">{{ todo.description }}</textarea></div><div class="mb-3 form-check"><input type="checkbox" class="form-check-input" name="completed"{% if todo.completed %}checked{% endif %}><label class="form-check-label">Completed</label></div><button type="submit" class="btn btn-primary">Update</button><a href="{{ url_for('main.index') }}" class="btn btn-secondary">Cancel</a></form>
{% endblock %}

样式文件:app/static/style.css

/* 基础样式 */
body {background-color: #f8f9fa;padding: 20px;
}.container {max-width: 800px;background: white;padding: 30px;border-radius: 10px;box-shadow: 0 0 10px rgba(0,0,0,0.1);
}/* Todo项样式 */
.list-group-item {margin-bottom: 10px;transition: all 0.3s ease;
}.list-group-item-success {background-color: #d4edda;border-color: #c3e6cb;
}/* 表单样式 */
form {background: #f8f9fa;padding: 20px;border-radius: 8px;margin-bottom: 30px;
}.form-control:focus {box-shadow: none;border-color: #80bdff;
}/* 按钮间距 */
.btn {margin-right: 8px;
}/* 完成状态文字 */
.list-group-item-success h5 {text-decoration: line-through;color: #155724;
}/* 时间戳样式 */
.text-muted {font-size: 0.85em;display: block;margin-top: 5px;
}

模板文件:base.html (app/templates/base.html)

<!DOCTYPE html>
<html>
<head><title>Todo App</title><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css"><link rel="stylesheet" href="{{ url_for('static', filename='style.css') }}">
</head>
<body><div class="container mt-4">{% block content %}{% endblock %}</div>
</body>
</html>

index.html (app/templates/index.html)

{% extends "base.html" %}{% block content %}<h1 class="mb-4">Todo List</h1><form method="POST" class="mb-4"><div class="mb-3"><input type="text" class="form-control" name="title" placeholder="Title" required></div><div class="mb-3"><textarea class="form-control" name="description" placeholder="Description"></textarea></div><button type="submit" class="btn btn-primary">Add Todo</button></form><div class="list-group">{% for todo in todos %}<div class="list-group-item {% if todo.completed %}list-group-item-success{% endif %}"><div class="d-flex justify-content-between align-items-center"><div><h5>{{ todo.title }}</h5><p class="mb-0">{{ todo.description }}</p><small class="text-muted">{{ todo.created_at.strftime('%Y-%m-%d %H:%M') }}</small></div><div><a href="{{ url_for('main.edit', id=todo.id) }}" class="btn btn-sm btn-warning">Edit</a><a href="{{ url_for('main.delete', id=todo.id) }}" class="btn btn-sm btn-danger">Delete</a></div></div></div>{% endfor %}</div>
{% endblock %}

运行脚本:run.py

from app import create_appapp = create_app()if __name__ == '__main__':app.run(debug=True)

以上为全部代码,可以将其复制到对应文件创建。

三、install flask和运行项目

在todo文件目录下打开cmd窗口,激活todoenv环境

conda activate todoenv

刚才requirement.txt已经有安装依赖了,执行命令,安装项目依赖

pip install -r requirements.txt

设置环境变量,我是Windows

set FLASK_APP=run.py
set FLASK_DEBUG=1

初始化数据库

flask db init       # 首次运行需要初始化迁移仓库
flask db migrate    # 生成迁移脚本
flask db upgrade    # 应用迁移到数据库

我这里已经创建过了,所以一次存在不为空了

运行应用

flask run

在本地浏览器打开http://127.0.0.1:5000网址

可以看到,我之前已经运行过这个,数据库在本地也有值了,所以数据库正常运行了,可以新建todo,以及修改删除

Ctrl + C结束程序退出

四、项目结构讲解

项目根目录 todoapp/

todoapp/
├── app/            # 核心应用代码
├── config.py       # 全局配置文件
├── requirements.txt # 项目依赖清单
└── run.py          # 启动脚本

核心应用模块 app/

文件/目录作用
__init__.py应用工厂函数
• 初始化 Flask 应用实例
• 整合配置/路由/模型等模块
models.py数据模型
• 定义数据库表结构 (使用 SQLAlchemy 或 Peewee 等 ORM)
routes.py路由控制器
• 处理 HTTP 请求与响应
• 业务逻辑的主要实现位置
templates/Jinja2 模板
• 存放 HTML 模板文件
• 通过 base.html 实现模板继承
static/静态资源
• 存放 CSS/JavaScript/图片等文件
• 通过 /static/路径 访问

该项目遵循MVC模式:模型(Model)、视图(View)和控制器(Controller)

模型(Model):负责处理数据和业务逻辑,像数据的存储、检索、更新等操作都由它完成。

  • app/models.py:此文件通常定义了应用的数据模型。在一个待办事项应用(todoapp)里,会定义待办事项的类,包含待办事项的属性(如标题、描述、完成状态等)以及对这些数据进行操作的方法(如添加、删除、更新待办事项等)。

视图(View):负责将模型中的数据呈现给用户,通常是用户界面,比如网页、图形界面等。

  • app/templates/ 目录:该目录存放 HTML 模板文件,这些文件用于展示数据给用户。
    • base.html:通常是基础模板,包含所有页面共有的部分,像头部、导航栏、底部等,其他模板可以继承它。
    • index.html:一般用于展示待办事项列表,从模型获取待办事项数据并渲染成 HTML 页面。
    • edit.html:用于编辑单个待办事项的页面,同样从模型获取数据并提供编辑界面。

控制器(Controller):接收用户的输入,调用模型进行相应的业务处理,再选择合适的视图展示处理结果。

  • app/routes.py:该文件定义了应用的路由和视图函数,负责接收用户的请求,调用模型进行数据处理,然后选择合适的视图进行渲染

整体交互流程

  1. 用户通过浏览器访问应用的 URL,请求会发送到 app/routes.py 中的相应路由。
  2. 路由对应的视图函数被调用,视图函数根据需求调用 app/models.py 中的模型进行数据处理。
  3. 模型处理完数据后,视图函数选择合适的 HTML 模板(app/templates/ 目录下的文件),并将处理后的数据传递给模板。
  4. 模板引擎将数据填充到 HTML 模板中,生成最终的 HTML 页面返回给用户浏览器进行显示。

浏览器 → run.py → app/__init__.py (创建app) → routes.py (处理逻辑) → models.py (操作数据库) → templates/*.html (渲染) → 返回响应

    浏览器->>run.py: 发起HTTP请求run.py->>__init__.py: 创建app实例__init__.py->>routes.py: 注册路由routes.py->>models.py: 调用数据库操作models.py->>数据库: 执行SQL数据库-->>models.py: 返回数据models.py-->>routes.py: 返回模型对象routes.py-->>浏览器: 渲染模板响应

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/39257.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ctfshow WEB web2

1.查当前数据库名称 or 11 union select 1,database(),3 limit 1,2;#-- 得到数据库名称web2 2.查看数据库表的数量 or 11 union select 1,(select count(*) from information_schema.tables where table_schema web2),3 limit 1,2;#-- 得到数据库表数量为2 3.查表的名字 第…

【Git】--- 分支管理

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏&#xff1a; Git 本篇博客我们来介绍Git的一个重要功能之一 ---- 分支。我们将讲解关于分支的各种操作&#xff0c;以及如何帮助我们进行开发。 &#x1f3e0; 理解分支…

系统思考与心智模式

“问题不是出在我们做了多少&#xff0c;而是出在我们做了什么。” — 赫尔曼凯恩 “一分耕耘一分收获”&#xff0c;这似乎是我们脑海中根深蒂固的心智模式。今天&#xff0c;我在一家餐厅用餐&#xff0c;店员告诉我&#xff0c;打卡收藏可以获得一份小食。没过多久&#xf…

纯文本驱动的数据可视化革命——AI生成图表「图表狐」全场景深度解析

一、技术架构重定义 图表狐核心能力边界 ✅ 纯文本输入&#xff1a;支持任意格式文字描述&#xff08;会议纪要/邮件/手写笔记&#xff09; ✅ 智能解析引擎&#xff1a; 实体识别&#xff08;数值/时间/分类维度&#xff09; 语义纠错&#xff08;自动修复错别字/单位混乱&…

多线程 --- 进程和线程的基本知识

进程 前面我们提到了一个概念是&#xff0c;多任务操作系统&#xff0c;即希望该系统能够同时运行多个程序。本质上说&#xff0c;进程&#xff0c;就算用来解决”并发编程“这样的问题的。 在一些特定的情况下&#xff0c;进程的表现&#xff0c;其实并不能很好的解决”并发…

SCI英文论文Accepted后的第一步——Rights and Access

SCI英文论文Accepted后的第一步——Rights and Access 目录 SCI英文论文Accepted后的第一步——Rights and AccessBased on information provided the embargo period/end date is 24 months. 因为选择闭源**Rights and Access(版权与访问权限)**环节是关键第一步,具体操作流…

流程控制语句

python中的流程控制语句有三种&#xff0c;顺序结构、条件结构和循环结构 1&#xff09;顺序结构&#xff1a; 从上往下&#xff0c;从左到右&#xff0c;依次逐行执行。 #顺序结构python print(start) print(hello world1 ) print(hello world2 ) print(hello world3 ) pri…

2.4 关键路径法

项目进度管理核心工具全解析 &#x1f680; 一、关键路径法&#xff08;CPM&#xff09;精要 1. 核心概念图解 #mermaid-svg-5MOABZm9lR8A53ss {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-5MOABZm9lR8A53ss .e…

Unity 实现一个简易可拓展性的对话系统

本人能力有限,一切实现仅供参考,如有不足还请斧正 起因是我看到学校社团内有人做了对话系统的分享,我想了想之前没写过这种东西,而Fungus插件教程太老了,NodeCanvas插件学习成本又比较高,我就干脆寻找资料 加上自己迭代一下,花了一天时间完成了这个对话系统 目录 1.介绍 2.核…

架构思维:通用系统设计方法论_从复杂度分析到技术实现指南

文章目录 Question订单履约原始架构痛点目标架构架构图说明关键设计点优点 设计方法论复杂来源解决方案评估标准从设计原则出发 技术实现 &#xff08;以选型Redis为例&#xff09;Redis消息队列的实现细节高可用设计 总结 Question 我们经常聊如何设计一个比较完善的系统&…

llama源码学习·model.py[7]Transformer类

一、源码展示 class Transformer(nn.Module):def __init__(self, params: ModelArgs):super().__init__()self.params paramsself.vocab_size params.vocab_sizeself.n_layers params.n_layersself.tok_embeddings VocabParallelEmbedding(params.vocab_size, params.dim,…

MD2Card(markdown)

MD2Card 介绍&#xff1a; 1.小红书爆款神器&#xff0c;Markdown笔记秒转高颜值卡片 2.实时预览15种主题&#xff0c;自动拆长文&#xff0c;图片/SVG导出即用 3.零门槛不登录&#xff0c;免费无限生成&#xff0c;专治排版废和设计手残党 网站地址&#xff1a; https://md2…

第二节第一部分:String字符串

一、导包 二、String字符串 三、String注意事项 四、字符串的比较 五、面试例题 六、String案例一 需求分析&#xff1a; 代码&#xff1a; package com.StringTest;import java.util.Scanner;public class StingTest {public static void main(String[] args) {//1.开发一个…

动态规划(01背包恰好装满型详解):和为目标值的最长子序列长度

0-1背包&#xff1a;有n个物品&#xff0c;第i个物品的体积为w[i]&#xff0c;价值为v[i]&#xff0c;每个物品至多选择一个&#xff0c;求体积和不超过capacity的最大价值和。 对于第i个物品&#xff0c;我们只有两种选择&#xff1a;选&#xff0c;或者不选。如果选&#xf…

Spring漏洞再现

一、CVE-2017-8046 1、开环境 2、访问目录 /customers/1 3、在当前页抓包&#xff0c;并修改数据包 PATCH /customers/1 HTTP/1.1 Host: 150.158.199.164:8080 Accept-Encoding: gzip, deflate Accept: */* User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1;…

Ftrans飞驰云联受邀参加“2025汽车零部件CIO年会“并荣获智象奖

2025年3月6日&#xff0c;由栖观汽车、栖观资讯和飞羽商务主办的“2025第二届中国汽车&零部件CIO年会暨智象奖颁奖盛典”于上海盛大召开&#xff0c;Ftrans飞驰云联作为国内领先的企业文件传输与数据交换解决方案提供商&#xff0c;受邀出席了年会&#xff0c;并凭借卓越的…

西门子 CPU 1513-1 PN TCP Server 接收字符串前多了一个问号

TIA V17编程环境中(CPU 1513-1 PN),调用TSEND_C以TCP协议向TCP Server发送字符串:abded1234,TCP Server接收到的字符串多了一个问号:?avded1234. TSEND_C 指令的 DATA DB为非优化string类型数据 截图如下: 字符串前面两个字节不是起始字符,第一个是字节是字符串最大长度…

Matlab2024a免费版下载教程

Matlab是一个高性能的数学计算与仿真软件&#xff0c;广泛应用于科学计算、数据分析、算法开发以及工程绘图等多个领域。它提供了强大的矩阵运算能力、丰富的内置函数库以及灵活的编程环境&#xff0c;使得用户能够高效地解决复杂的数学问题。本文&#xff0c;我将为大家详细介…

SpringCould微服务架构之Docker(1)

项目中微服务比较多的时候&#xff0c;一个一个手动的部署太麻烦了&#xff0c;所以就需要用到Docker。 项目部署中的问题&#xff1a; Docker是一种快速交付应用、运行应用的技术。

软件公司高新技术企业代办:机遇与陷阱并存-优雅草卓伊凡

软件公司高新技术企业代办&#xff1a;机遇与陷阱并存-优雅草卓伊凡 在科技飞速发展的当下&#xff0c;软件公司如雨后春笋般涌现&#xff0c;众多企业渴望通过申请高新技术企业来获得政策支持与发展助力。随之而来的&#xff0c;是高新技术企业代办业务的兴起。然而&#xff…