python框架flask知識(shí)總結(jié)
一、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)圖注冊進(jìn)去了。
接下來看static目錄,這個(gè)目錄從字面意思就可以理解了,是我們的static靜態(tài)文件存放目錄。
然后就是templates目錄,即模板存放目錄。
views目錄,主角終于登場了,這里存放的就是視圖函數(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
二、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
2.2 在app目錄下建立models.py(ORM模型文件)
app/models.py
from app import db # from sqlalchemy.ext.declarative import declarative_base # Base = declarative_base() # 之前我們在創(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ù)
還記不記得我們在sqlalchemy中手動(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') # 還記不記得我們在sqlalchemy中手動(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表。
到此這篇關(guān)于python框架flask知識(shí)總結(jié)的文章就介紹到這了,更多相關(guān)python flask內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何從Python字符串中刪除最后一個(gè)分號(hào)或者逗號(hào)
這篇文章主要介紹了從?Python?中的字符串中刪除最后一個(gè)分號(hào)或者逗號(hào)的兩種方法,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04Pytorch建模過程中的DataLoader與Dataset示例詳解
這篇文章主要介紹了Pytorch建模過程中的DataLoader與Dataset,同時(shí)PyTorch針對(duì)不同的專業(yè)領(lǐng)域,也提供有不同的模塊,例如?TorchText,?TorchVision,?TorchAudio,這些模塊中也都包含一些真實(shí)數(shù)據(jù)集示例,本文給大家介紹的非常詳細(xì),需要的朋友參考下吧2023-01-01python實(shí)現(xiàn)unicode轉(zhuǎn)中文及轉(zhuǎn)換默認(rèn)編碼的方法
這篇文章主要介紹了python實(shí)現(xiàn)unicode轉(zhuǎn)中文及轉(zhuǎn)換默認(rèn)編碼的方法,結(jié)合實(shí)例形式分析了Python針對(duì)Unicode編碼操作的相關(guān)技巧及編碼轉(zhuǎn)換中的常見問題解決方法,需要的朋友可以參考下2017-04-04python使用xlsx和pandas處理Excel表格的操作步驟
python的神器pandas庫就可以非常方便地處理excel,csv,矩陣,表格 等數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于python使用xlsx和pandas處理Excel表格的操作步驟,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01python調(diào)用接口的4種方式代碼實(shí)例
這篇文章主要介紹了python調(diào)用接口的4種方式代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11Python中的None與 NULL(即空字符)的區(qū)別詳解
這篇文章主要介紹了Python中的None與 NULL(即空字符)的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09