不管有沒有學(xué)習(xí)python的web編程,很多小伙伴還是會(huì)聽說過flask框架的大名。作為一個(gè)輕量級(jí)的web應(yīng)用框架,學(xué)習(xí)flask的難度是比較低的。小編現(xiàn)在帶來一篇flask知識(shí)點(diǎn)總結(jié),以幫助小伙伴們學(xué)習(xí)flask怎么使用。
一、Flask藍(lán)圖目錄
我們之前寫的Flask項(xiàng)目都是自己組織的目錄結(jié)構(gòu),其實(shí)Flask官方有其推薦的目錄結(jié)構(gòu),以下就是一個(gè)符合官方推薦的Flask小型應(yīng)用的項(xiàng)目結(jié)構(gòu)目錄示例,如下:
如圖,這就是我們建立好的一個(gè)目錄結(jié)構(gòu),一層一層的看一下,首先是app目錄,它就是我們的主應(yīng)用程序目錄了,其中有一個(gè)__init__.py文件,里面的內(nèi)容如下:
app/init.py
from flask import Flask
from .views.acc import acc_bp
from .views.user import user_bp
def create_app():
my_app = Flask(__name__)
my_app.register_blueprint(acc_bp)
my_app.register_blueprint(user_bp)
return my_app
app/__init__.py
__init__.py
就是構(gòu)建app的一個(gè)函數(shù),并且將views中的藍(lán)圖注冊(cè)進(jìn)去了。
接下來看static目錄,這個(gè)目錄從字面意思就可以理解了,是我們的static靜態(tài)文件存放目錄。
然后就是templates目錄,即模板存放目錄。
views目錄,主角終于登場(chǎng)了,這里存放的就是視圖函數(shù)文件,也就是我們Blueprint
,每一個(gè)文件就是一個(gè)Blueprint,如下:
views/acc.py
from flask import Blueprint
acc_bp = Blueprint('acc', __name__)
@acc_bp.route("/acc")
def accfunc():
return "my_app.acc"
views/acc.py
views/user.py
from flask import Blueprint
user_bp = Blueprint('user', __name__)
@user_bp.route("/login")
def user_login():
return "my_app.user"
views/user.py
接下來就是關(guān)鍵性的一個(gè)文件manager.py,項(xiàng)目的啟動(dòng)文件,內(nèi)容如下:
manager.py
from app import create_app
my_app = create_app()
if __name__ == '__main__':
my_app.run()
manager.py
from app import create_app
my_app = create_app()
if __name__ == '__main__':
my_app.run()
manager.py
二、Flask-SQLAlchemy
1、安裝?
pip install Flask-SQLAlchemy
?
2、接下來基于上面的Flask項(xiàng)目,我們要加入Flask-SQLAlchemy讓項(xiàng)目變得生動(dòng)起來
2.1 加入Flask-SQLAlchemy第三方組件
app/__init__.py
from flask import Flask
from flask_sqlalchemy import SQLAlchemy # 導(dǎo)入Flask-SQLAlchemy中的SQLAlchemy
db = SQLAlchemy() # 實(shí)例化SQLAlchemy
# 注意:實(shí)例化SQLAlchemy的代碼必須要在引入藍(lán)圖之前
# 引入藍(lán)圖
from .views.acc import acc_bp
from .views.user import user_bp
def create_app():
my_app = Flask(__name__)
# 初始化app配置,專門針對(duì)SQLAlchemy 進(jìn)行配置
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的連接超時(shí)時(shí)間
my_app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
db.init_app(my_app) # 初始化SQLAlchemy , 本質(zhì)就是將以上的配置讀取出來
my_app.register_blueprint(acc_bp)
my_app.register_blueprint(user_bp)
return my_app
app/__init__.py
from flask import Flask
from flask_sqlalchemy import SQLAlchemy # 導(dǎo)入Flask-SQLAlchemy中的SQLAlchemy
db = SQLAlchemy() # 實(shí)例化SQLAlchemy
# 注意:實(shí)例化SQLAlchemy的代碼必須要在引入藍(lán)圖之前
# 引入藍(lán)圖
from .views.acc import acc_bp
from .views.user import user_bp
def create_app():
my_app = Flask(__name__)
# 初始化app配置,專門針對(duì)SQLAlchemy 進(jìn)行配置
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的連接超時(shí)時(shí)間
my_app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
db.init_app(my_app) # 初始化SQLAlchemy , 本質(zhì)就是將以上的配置讀取出來
my_app.register_blueprint(acc_bp)
my_app.register_blueprint(user_bp)
return my_app
app/__init__.py
2.2 在app目錄下建立models.py(ORM模型文件)
app/models.py
from app import db
# from sqlalchemy.ext.declarative import declarative_base
# Base = declarative_base()
# 之前我們?cè)趧?chuàng)建數(shù)據(jù)表的時(shí)候都要做這樣一件事,然而Flask-SQLAlchemy已經(jīng)為我們把 Base 封裝好了,即db.Model
# 建立users數(shù)據(jù)表
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應(yīng)用上下文管理了
# 離線腳本:
with my_app.app_context():
db.drop_all() # 刪除所有表
db.create_all() # 創(chuàng)建表
app/models.py
2.3 登錄視圖函數(shù)
還記不記得我們?cè)趕qlalchemy中手動(dòng)打開會(huì)話 db_session
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(engine)
db_session = Session()
現(xiàn)在不用了,因?yàn)?Flask-SQLAlchemy 也已經(jīng)為我們做好會(huì)話打開的工作
from flask import Blueprint, request, render_template
user_bp = Blueprint('user', __name__)
from app.models import Users
from 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')
# 還記不記得我們?cè)趕qlalchemy中手動(dòng)打開會(huì)話 db_session
# from sqlalchemy.orm import sessionmaker
# Session = sessionmaker(engine)
# db_session = Session()
# 現(xiàn)在不用了,因?yàn)?Flask-SQLAlchemy 也已經(jīng)為我們做好會(huì)話打開的工作
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
2.4 登陸頁面
<!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
三、Flask-Script
1、安裝?
pip install Flask-Script
?
2、接下來再基于上面的項(xiàng)目,加入Flask-Script,使我們可以用命令啟動(dòng)項(xiàng)目
其實(shí)本部分就是為下面的Flask-Migrate做鋪墊,F(xiàn)lask-Script 顧名思義就是 Flask 的腳本。你是否還記得Django的啟動(dòng)命令呢?沒錯(cuò),就是 python manager.py runserver,其實(shí)Flask也可以做到,基于 Flask-Script 就可以了。
3.1 將Flask-Script加入到Flask項(xiàng)目中
from flask_script import Manager # 導(dǎo)入Flask-Script中的Manager
from app import create_app
my_app = create_app()
manager = Manager(my_app) # 讓app支持manager
if __name__ == '__main__':
# my_app.run()
manager.run() # 替換原來的 my_app.run() 就可以了
manager.py
3.2 使用命令啟動(dòng)Flask項(xiàng)目
python manager.py runserver
3.3 啟動(dòng)Flask項(xiàng)目,并更改配置參數(shù)(監(jiān)聽的IP地址和端口號(hào))
python manager.py runserver -h 0.0.0.0 -p 9527
3.4 高級(jí)操作 - 自定制腳本命令
方式一:@manager.command
from flask_script import Manager # 導(dǎo)入Flask-Script中的Manager
from app import create_app
my_app = create_app()
manager = Manager(my_app) # 讓app支持manager
@manager.command
def runflask(arg):
# my_app.run() # 釋放此句項(xiàng)目humg住
print(arg)
if __name__ == '__main__':
# my_app.run()
manager.run() # 替換原來的 my_app.run() 就可以了
manager.py
執(zhí)行命令:
python manager.py runflask 22
結(jié)果如下圖:
執(zhí)行命令:
python manager.py talk -n 你 -s 厲害
python manager.py talk --name 我 --say 厲害
四、Flask-Migrate
1、安裝
pip install Flask-Migrate
2、繼續(xù)基于上面的項(xiàng)目,使Flask項(xiàng)目支持makemigration和migrate
4.1 將 Flask-Migrate (注意:Flask-Migrate要依賴Flask-Script組件)加入到項(xiàng)目中
from flask_script import Manager # 導(dǎo)入Flask-Script中的Manager
# 導(dǎo)入 Flask-Migrate 中的 Migrate 和 MigrateCommand
# 這兩個(gè)東西說白了就是想在 Flask-Script 中添加幾個(gè)命令和指令而已
from flask_migrate import Migrate, MigrateCommand
from app import create_app
my_app = create_app()
manager = Manager(my_app) # 讓app支持manager
from app import db
Migrate(my_app, db) # 既然是數(shù)據(jù)庫遷移,那么就得告訴他數(shù)據(jù)庫在哪里,并且告訴他要支持哪個(gè)app
# 接下來再告訴manager 有新的指令了,這個(gè)新指令在MigrateCommand 中存著呢
manager.add_command("database", MigrateCommand) # 當(dāng)你的命令中出現(xiàn) database 指令,則去MigrateCommand中尋找對(duì)應(yīng)關(guān)系
"""
數(shù)據(jù)庫遷移指令:
python manager.py database init
python manager.py database migrate # 相當(dāng)于Django中的 makemigration
python manager.py database upgrade # 相當(dāng)于Django中的 migrate
"""
@manager.command
def runflask(arg):
# my_app.run() # 釋放此句項(xiàng)目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
4.2 執(zhí)行數(shù)據(jù)庫初始化指令
python manager.py database init
此時(shí)你會(huì)發(fā)現(xiàn)你的項(xiàng)目目錄中出現(xiàn)了一個(gè)migrations目錄,如下圖:
4.3 執(zhí)行數(shù)據(jù)庫遷移指令
python manager.py database migrate # 相當(dāng)于Django中的 makemigration
python manager.py database upgrade # 相當(dāng)于Django中的 migrate
結(jié)果如下圖:
此時(shí)你會(huì)發(fā)現(xiàn)數(shù)據(jù)庫中出現(xiàn)了一個(gè)users表。
小結(jié)
到此這篇關(guān)于python框架flask知識(shí)總結(jié)的文章就介紹到這了,更多相關(guān)python flask內(nèi)容請(qǐng)搜索W3Cschool以前的文章或繼續(xù)瀏覽下面的相關(guān)文章。希望大家以后多多支持W3Cschool!