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

news2025/3/27 15:46:01

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_dotenv

basedir = 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 Config

db = 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 bp
    app.register_blueprint(bp)

    return app

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

from datetime import datetime
from app import db

class 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 db

bp = 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.form
        db.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_app

app = 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.coloradmin.cn/o/2321024.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

AI+金融 应用 使用DeepSeek、Qwen等大模型输入自然语言,得到通达信等行情软件公式代码,导入后使用

AI金融 应用 使用DeepSeek、Qwen等大模型输入自然语言&#xff0c;得到通达信等行情软件公式代码&#xff0c;导入后使用。不会编程&#xff0c;也能行情软件中实现个性化条件选股&#xff0c;个性化技术指标。 AIbxm低估值趋势选股策略&#xff0c;参考提示词&#xff1a; 编…

C++20 中的同步输出流:`std::basic_osyncstream` 深入解析与应用实践

文章目录 一、std::basic_osyncstream 的背景与动机二、std::basic_osyncstream 的基本原理三、std::basic_osyncstream 的使用方法&#xff08;一&#xff09;基本用法&#xff08;二&#xff09;多线程环境下的使用&#xff08;三&#xff09;与文件流的结合 四、std::basic_…

【嵌入式硬件】三款DCDC调试笔记

关于开关电源芯片&#xff0c;重点关注输入电源范围、输出电流、最低压降。 1.MP9943: 以MP9943为例&#xff0c;输入电压范围4-36V&#xff0c;输出最大电流3A&#xff0c;最低压降为0.3V 调整FB使正常输出为5.06V 给定6V空载、5V空载、5V带2A负载的情况&#xff1a; 6V带2A…

【FPGA开发】FPGA点亮LED灯(增加按键暂停恢复/复位操作)

目录 一、VScode下载安装 1.1 官网下载 1.2 安装插件 二、LED流水灯点亮 2.1 任务说明 2.2 新建项目 2.3 创建Verilog文件添加至顶层实体 2.4 引脚分配 2.5 选择烧录器 2.6 添加烧录文件&#xff06;下载 2.7 烧录结果 三、增加按键操作 3.1 按键暂停和恢复功能&…

Spring MVC 执行流程:一个请求在 Spring MVC 中是如何执行的?

当用户发送一个 HTTP 向 Spring MVC 应用&#xff0c;该请求在 Spring MVC 的执行流程如下&#xff1a; 当用户向 Spring MVC 发起一个 HTTP 请求&#xff0c;该请求会被 Dispatcher Servlet&#xff08;前端控制器&#xff09;拦截&#xff1b;DispatcherServlet 调用 Handler…

三主热备架构

1.要求 角色主机名软件IP地址用户client192.168.72.90keepalivedvip192.168.72.100masterserverAkeepalived, nginx192.168.72.30backupserverBkeepalived, nginx192.168.72.31backupserverCkeepalived, nginx192.168.72.32webtomcat1tomcat192.168.72.41webtomcat2tomcat192.1…

JavaScript | 爬虫逆向 | 语法基础| 01

一、摘要 实践是最好的导师 二、环境配置 在开始之前&#xff0c;需要确保你的计算机上已经安装了 Node.js。Node.js 是一个开源的、跨平台的 JavaScript 运行时环境&#xff0c;它允许你在服务器端运行 JavaScript 代码。 1. 下载 安装地址&#xff1a;https://nodejs.org…

字节跳动实习生主导开发强化学习算法,助力大语言模型性能突破

目录 禹棋赢的背景与成就 主要成就 DAPO算法的技术细节 算法优势 禹棋赢的研究历程 关键时间节点 字节跳动的“Top Seed人才计划” 计划特点 小编总结 在大模型时代&#xff0c;经验不再是唯一的衡量标准&#xff0c;好奇心、执行力和对新技术的敏锐洞察力成为推动技术…

前后端+数据库的项目实战:hbu迎新网-较复杂(下)javaweb

目录 十一、实现对内容的富文本编辑&#xff08;换行、图片颜色等等样式&#xff09; &#xff08;1&#xff09;下载富文本编辑器&#xff0c;引入资源 &#xff08;2&#xff09;将原项目的内容部分替换为富文本编辑器 1、替换添加页面 2、替换修改页面&#xff08;和添…

Redis、Memcached应用场景对比

环境 Redis官方网站&#xff1a; Redis - The Real-time Data Platform Redis社区版本下载地址&#xff1a;Install Redis | Docs Memcached官方网站&#xff1a;memcached - a distributed memory object caching system Memcached下载地址&#xff1a;memcached - a dis…

【单片机通信技术应用——学习笔记三】液晶屏显示技术,取模软件的应用

一、液晶显示技术简介 1.RGB信号线 RGB是一种色彩模式&#xff0c;是工业界的一种颜色标准&#xff0c;是通过红&#xff08;R&#xff09;、绿&#xff08;G&#xff09;、蓝&#xff08;B&#xff09;三个颜色通道的变化&#xff0c;以及它们相互之间的叠加来得到各式各样的…

MySQL颠覆版系列————MySQL新特性(开启数据库的新纪元)上篇

文章目录 前言一、窗口函数&#xff08;Window Functions&#xff09;1.1 窗口函数概念1.2 常见的窗口函数 二、公用表表达式&#xff08;Common Table Expressions, CTEs&#xff09;2.1 公用表表达式的概念2.2 常见的公用表表达式 三、JSON增强3.1 JSON增强的概念3.2 常见的J…

MySQL 调优:查询慢除了索引还能因为什么?

文章目录 情况一&#xff1a;连接数过小情况二&#xff1a;Buffer Pool 太小 MySQL 查询慢除了索引还能因为什么&#xff1f;MySQL 查询慢&#xff0c;我们一般也会想到是因为索引&#xff0c;但除了索引还有哪些原因会导致数据库查询变慢呢&#xff1f; 以下以 MySQL 中一条 S…

如何在百度搜索上删除与自己名字相关的资料

个人信息的网络足迹如同一张无形的网&#xff0c;将我们与世界的每一个角落紧密相连。然而&#xff0c;当某些与自己名字相关的资料不再希望被公众轻易检索到时&#xff0c;如何在百度搜索中有效“隐身”&#xff0c;成为了一个亟待解决的问题。面对复杂多变的网络环境&#xf…

使用外部事件检测接入 CDH 大数据管理平台告警

CDH 大数据管理平台 CDH&#xff08;Cloudera Distribution Hadoop&#xff09;是一个企业级的大数据平台&#xff0c;由 Cloudera 公司提供&#xff0c;它包含了 Apache Hadoop 生态系统中的多种开源组件&#xff0c;并对其进行了优化和集成&#xff0c;以支持大规模数据存储…

MongoDB(五) - Studio 3T 下载与安装教程

文章目录 前言一、Studio 3T 简介二、下载及安装1. 下载2. 安装 三、使用Studio 3T连接MongoDB 前言 本文旨在全面且深入地为你介绍 Studio 3T。从其丰富的功能特性、跨平台使用的便捷性&#xff0c;到详细的下载安装步骤&#xff0c;以及关键的连接 MongoDB 操作&#xff0c;…

汽车制造MES

一、整体生产工序 整车的车间主要分为4个部分&#xff1a;冲压、焊装、涂装、总装、整车入库 系统架构 二、车间概括 1.冲压车间 2.焊装车间 3.涂装车间 4.总装车间 1.整车装配的部件都要可追溯、数据实时性要求高、涉及分装与总装的协调、物流配送的协调、质量批处理的协调、…

信奥赛CSP-J复赛集训(模拟算法专题)(26):P5412 [YNOI2019] 排队

信奥赛CSP-J复赛集训(模拟算法专题)(26):P5412 [YNOI2019] 排队 题目描述 小明所在的班级要举办一场课外活动,在活动开始之前老师告诉小明:“需要把男女生分成两队,并且每一队都要按照身高从矮到高进行排序”。但是由于小明的马虎,没有把老师的安排转达给同学,导致全…

基于开源模型的微调训练及瘦身打造随身扫描仪方案__用AI把手机变成文字识别小能手

基于开源模型的微调训练及瘦身打造随身扫描仪方案__用AI把手机变成文字识别小能手 一、准备工作&#xff1a;组装你的"数码工具箱" 1. 安装基础工具&#xff08;Python环境&#xff09; 操作步骤&#xff1a; 访问Python官网下载安装包安装时务必勾选Add Python to…

在 Offset Explorer 中配置多节点 Kafka 集群的详细指南

一、是否需要配置 Zookeeper&#xff1f; Kafka 集群的 Zookeeper 依赖性与版本及运行模式相关&#xff1a; Kafka 版本是否需要 Zookeeper说明0.11.x 及更早版本✅ 必须配置Kafka 完全依赖 Zookeeper 管理元数据2.8 及以下版本✅ 必须配置Kafka 依赖外置或内置的 Zookeeper …