您好,登錄后才能下訂單哦!
今天小編給大家分享一下flask框架如何使用的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
我們建立好的一個目錄結構,一層一層的看一下,首先是app目錄,它就是我們的主應用程序目錄了,其中有一個__init__.py文件,里面的內容如下:
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
就是構建app的一個函數,并且將views中的藍圖注冊進去了。
接下來看static目錄,這個目錄從字面意思就可以理解了,是我們的static靜態文件存放目錄。
然后就是templates目錄,即模板存放目錄。
views目錄,主角終于登場了,這里存放的就是視圖函數文件,也就是我們Blueprint
,每一個文件就是一個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
接下來就是關鍵性的一個文件manager.py,項目的啟動文件,內容如下:
manager.py
from app import create_app
my_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 Flask
from flask_sqlalchemy import SQLAlchemy # 導入Flask-SQLAlchemy中的SQLAlchemy
db = SQLAlchemy() # 實例化SQLAlchemy
# 注意:實例化SQLAlchemy的代碼必須要在引入藍圖之前
# 引入藍圖
from .views.acc import acc_bp
from .views.user import user_bp
def 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_app
app/__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_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中手動打開會話 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中的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
python manager.py runserver
python manager.py runserver -h 0.0.0.0 -p 9527
方式一:@manager.command
from flask_script import Manager # 導入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() # 釋放此句項目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, MigrateCommand
from app import create_app
my_app = create_app()
manager = Manager(my_app) # 讓app支持manager
from app import db
Migrate(my_app, db) # 既然是數據庫遷移,那么就得告訴他數據庫在哪里,并且告訴他要支持哪個app
# 接下來再告訴manager 有新的指令了,這個新指令在MigrateCommand 中存著呢
manager.add_command("database", MigrateCommand) # 當你的命令中出現 database 指令,則去MigrateCommand中尋找對應關系
"""
數據庫遷移指令:
python manager.py database init
python manager.py database migrate # 相當于Django中的 makemigration
python manager.py database upgrade # 相當于Django中的 migrate
"""
@manager.command
def 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中的 makemigration
python manager.py database upgrade # 相當于Django中的 migrate
此時你會發現數據庫中出現了一個users表。
以上就是“flask框架如何使用”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。