- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章python框架flask知识总结由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
我们之前写的Flask项目都是自己组织的目录结构,其实Flask官方有其推荐的目录结构,以下就是一个符合官方推荐的Flask小型应用的项目结构目录示例,如下:
如图,这就是我们建立好的一个目录结构,一层一层的看一下,首先是app目录,它就是我们的主应用程序目录了,其中有一个__init__.py文件,里面的内容如下:
app/init.py 。
from flask import Flaskfrom .views.acc import acc_bpfrom .views.user import user_bpdef create_app(): my_app = Flask(__name__) my_app.register_blueprint(acc_bp) my_app.register_blueprint(user_bp) return my_appapp/__init__.py
__init__.py就是构建app的一个函数,并且将views中的蓝图注册进去了.
接下来看static目录,这个目录从字面意思就可以理解了,是我们的static静态文件存放目录.
然后就是templates目录,即模板存放目录.
views目录,主角终于登场了,这里存放的就是视图函数文件,也就是我们Blueprint,每一个文件就是一个Blueprint,如下: views/acc.py 。
from flask import Blueprintacc_bp = Blueprint("acc", __name__)@acc_bp.route("/acc")def accfunc(): return "my_app.acc"views/acc.py
views/user.py 。
from flask import Blueprintuser_bp = Blueprint("user", __name__)@user_bp.route("/login")def user_login(): return "my_app.user"views/user.py
接下来就是关键性的一个文件manager.py,项目的启动文件,内容如下:
manager.py 。
from app import create_appmy_app = create_app()if __name__ == "__main__": my_app.run()manager.py
1、安装 。
pip install Flask-SQLAlchemy
2、接下来基于上面的Flask项目,我们要加入Flask-SQLAlchemy让项目变得生动起来 。
app/__init__.py 。
from flask import Flaskfrom flask_sqlalchemy import SQLAlchemy # 导入Flask-SQLAlchemy中的SQLAlchemydb = SQLAlchemy() # 实例化SQLAlchemy# 注意:实例化SQLAlchemy的代码必须要在引入蓝图之前# 引入蓝图from .views.acc import acc_bpfrom .views.user import user_bpdef create_app(): my_app = Flask(__name__) # 初始化app配置,专门针对SQLAlchemy 进行配置 my_app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://root:@127.0.0.1:3306/wll?charset=utf8" my_app.config["SQLALCHEMY_POOL_SIZE"] = 5 # SQLAlchemy的连接池大小 my_app.config["SQLALCHEMY_POOL_TIMEOUT"] = 15 # SQLAlchemy的连接超时时间 my_app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False db.init_app(my_app) # 初始化SQLAlchemy , 本质就是将以上的配置读取出来 my_app.register_blueprint(acc_bp) my_app.register_blueprint(user_bp) return my_appapp/__init__.py
app/models.py 。
from app import db# from sqlalchemy.ext.declarative import declarative_base# Base = declarative_base()# 之前我们在创建数据表的时候都要做这样一件事,然而Flask-SQLAlchemy已经为我们把 Base 封装好了,即db.Model# 建立users数据表class Users(db.Model): __tablename__ = "users" # __table_args__ = {"useexisting": True} # Flask-SQLAlchemy 也为我们封装好了Column,Integer,String等 id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(32)) password = db.Column(db.String(32))if __name__ == "__main__": from app import create_app my_app = create_app() # 这里你要回顾一下Flask应用上下文管理了 # 离线脚本: with my_app.app_context(): db.drop_all() # 删除所有表 db.create_all() # 创建表app/models.py
还记不记得我们在sqlalchemy中手动打开会话 db_session 。
from sqlalchemy.orm import sessionmaker Session = sessionmaker(engine) db_session = Session()
现在不用了,因为 Flask-SQLAlchemy 也已经为我们做好会话打开的工作 。
from flask import Blueprint, request, render_templateuser_bp = Blueprint("user", __name__)from app.models import Usersfrom app import db@user_bp.route("/login", methods=["GET", "POST"])def user_login(): if request.method == "POST": username = request.form.get("username") password = request.form.get("password") # 还记不记得我们在sqlalchemy中手动打开会话 db_session # from sqlalchemy.orm import sessionmaker # Session = sessionmaker(engine) # db_session = Session() # 现在不用了,因为 Flask-SQLAlchemy 也已经为我们做好会话打开的工作 db.session.add(Users(name=username,password=password)) db.session.commit() # 查询 user_obj = Users.query.filter(Users.name == username and Users.password == password).first() if user_obj: return f"{user_obj.name}登录成功" return render_template("login.html")views/user.py
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title></head><body><form method="post" action=""> <input type="text" name="username"> <input type="password" name="password"> <input type="submit"></form></body></html>templates/login.html
1、安装 。
pip install Flask-Script
2、接下来再基于上面的项目,加入Flask-Script,使我们可以用命令启动项目 。
其实本部分就是为下面的Flask-Migrate做铺垫,Flask-Script 顾名思义就是 Flask 的脚本。你是否还记得Django的启动命令呢?没错,就是 python manager.py runserver,其实Flask也可以做到,基于 Flask-Script 就可以了.
from flask_script import Manager # 导入Flask-Script中的Managerfrom app import create_appmy_app = create_app()manager = Manager(my_app) # 让app支持managerif __name__ == "__main__": # my_app.run() manager.run() # 替换原来的 my_app.run() 就可以了manager.py
python manager.py runserver
python manager.py runserver -h 0.0.0.0 -p 9527
方式一:@manager.command 。
from flask_script import Manager # 导入Flask-Script中的Managerfrom app import create_appmy_app = create_app()manager = Manager(my_app) # 让app支持manager@manager.commanddef runflask(arg): # my_app.run() # 释放此句项目humg住 print(arg)if __name__ == "__main__": # my_app.run() manager.run() # 替换原来的 my_app.run() 就可以了manager.py
执行命令:
python manager.py runflask 22
结果如下图:
执行命令:
python manager.py talk -n 你 -s 厉害python manager.py talk --name 我 --say 厉害
1、安装 。
pip install Flask-Migrate
2、继续基于上面的项目,使Flask项目支持makemigration和migrate 。
from flask_script import Manager # 导入Flask-Script中的Manager# 导入 Flask-Migrate 中的 Migrate 和 MigrateCommand# 这两个东西说白了就是想在 Flask-Script 中添加几个命令和指令而已from flask_migrate import Migrate, MigrateCommandfrom app import create_appmy_app = create_app()manager = Manager(my_app) # 让app支持managerfrom app import dbMigrate(my_app, db) # 既然是数据库迁移,那么就得告诉他数据库在哪里,并且告诉他要支持哪个app# 接下来再告诉manager 有新的指令了,这个新指令在MigrateCommand 中存着呢manager.add_command("database", MigrateCommand) # 当你的命令中出现 database 指令,则去MigrateCommand中寻找对应关系"""数据库迁移指令:python manager.py database init python manager.py database migrate # 相当于Django中的 makemigrationpython manager.py database upgrade # 相当于Django中的 migrate"""@manager.commanddef runflask(arg): # my_app.run() # 释放此句项目humg住 print(arg)@manager.option("-n", "--name", dest="name")@manager.option("-s", "--say", dest="say")def talk(name, say): print(f"{name}可真{say}")if __name__ == "__main__": # my_app.run() manager.run() # 替换原来的 my_app.run() 就可以了manager.py
python manager.py database init
此时你会发现你的项目目录中出现了一个migrations目录,如下图:
python manager.py database migrate # 相当于Django中的 makemigrationpython manager.py database upgrade # 相当于Django中的 migrate
结果如下图:
此时你会发现数据库中出现了一个users表.
到此这篇关于python框架flask知识总结的文章就介绍到这了,更多相关python flask内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/xili2532/article/details/117096086 。
最后此篇关于python框架flask知识总结的文章就讲到这里了,如果你想了解更多关于python框架flask知识总结的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
积累和总结,是长期持续的过程 01 最近,很多朋友微信私聊关于「 butte-java-note 」仓库的话题; 这个「 Git仓库 」每年都会
我即将参加挑战测试,所以我不必参加数据库处理类(class)。尽管在过去的 5 年里我一直在使用数据库,但我还是忍不住对测试感到紧张。这是 50 个问题,有 2 部分:真/假部分和我实际编写 SQL
我的 groovy 代码将 Rabbit Native Plugin 用于 grails: def handleMessage(def body, MessageContext context) {
我想看看是否有人可以就我在 .NET 环境中的进一步知识提供任何建议... 这里有一点背景。我上了一所大学并获得了计算机科学学士学位(主要从事 C、Java 和 C++ 方面的工作)。大学毕业后在一家
我在 postgres 数据库中有一个表,该表用于测试环境,我们需要一次添加和删除多个列。问题是 postgres 最多有 1600 列,并且这个计数包括丢弃的列。我的表永远不会有 1600 个“未丢
作为业余程序员 3 年(主要是 Python 和 C)并且从未编写过超过 500 行代码的应用程序,我发现自己面临两个选择: (1) 学习数据结构和算法设计的基本知识,使我成为一名 l33t 计算机科
有人能告诉我为什么 Android 工作需要 Linux 知识吗?许多 Android 工作都以 Linux 作为先决条件。我可以很好地从 Windows 机器开发 Android 应用程序吗? 最佳
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
是否可以在 Drools 中保持知识 session ?如果是这样,如何? 我将事实存储在数据库中,并且每次添加新事实时,我都希望避免在新 session 中重新加载所有事实。 目前,当有新事实时,该
我对 C++ 有很好的了解,但从未深入研究 STL。我必须学习 STL 的哪一部分才能提高工作效率并减少工作中的缺陷? 谢谢。 最佳答案 I have good knowledge of C++ 恕我
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 7 年前。 Improve
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
在我从 SO answers here 和许多 BackBoneJs 示例中选择的示例之一中,我看到初始化函数知道模型将使用哪个 View 进行渲染。我不知道我现在有点偏见,这是一个好的做法还是取决于
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 12 年前。 Improve thi
我在我的网站上使用 C# 和 ASP.NET MVC 3 实现 OpenID 和 OAuth。我基于 DotNetOpenAuth用于后端和openid-selector对于前端。 我喜欢 openi
很长一段时间以来,我都在思考和研究C语言编译器以汇编形式的输出,以及CPU架构。我知道这对你来说可能很愚蠢,但在我看来有些东西是非常无效的。如果我错了,请不要生气,我不明白所有这些原则是有原因的。如果
我有一些 Python 知识,但我从来不认为自己对这门语言特别流利。我正在开发一个潜在的机器视觉项目,该项目将从 SimpleCV 中受益匪浅,但从时间的角度来看,我宁愿不必非常流利地使用 pytho
我是一名优秀的程序员,十分优秀!