欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python框架flask知識(shí)總結(jié)

 更新時(shí)間:2021年05月24日 17:02:09   作者:胖虎是只mao  
今天帶大家復(fù)習(xí)python框架的相關(guān)知識(shí),文中對(duì)flask作了非常詳細(xì)的介紹,對(duì)正在學(xué)習(xí)python的小伙伴們有很好的幫助,需要的朋友可以參考下

一、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)

    這篇文章主要介紹了從?Python?中的字符串中刪除最后一個(gè)分號(hào)或者逗號(hào)的兩種方法,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • Pytorch建模過程中的DataLoader與Dataset示例詳解

    Pytorch建模過程中的DataLoader與Dataset示例詳解

    這篇文章主要介紹了Pytorch建模過程中的DataLoader與Dataset,同時(shí)PyTorch針對(duì)不同的專業(yè)領(lǐng)域,也提供有不同的模塊,例如?TorchText,?TorchVision,?TorchAudio,這些模塊中也都包含一些真實(shí)數(shù)據(jù)集示例,本文給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2023-01-01
  • python實(shí)現(xiàn)unicode轉(zhuǎn)中文及轉(zhuǎn)換默認(rèn)編碼的方法

    python實(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-04
  • python使用xlsx和pandas處理Excel表格的操作步驟

    python使用xlsx和pandas處理Excel表格的操作步驟

    python的神器pandas庫就可以非常方便地處理excel,csv,矩陣,表格 等數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于python使用xlsx和pandas處理Excel表格的操作步驟,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • Python中內(nèi)建函數(shù)的簡單用法說明

    Python中內(nèi)建函數(shù)的簡單用法說明

    這篇文章主要介紹了Python中內(nèi)建函數(shù)的簡單用法說明,包括apply()、filter()、reduce()、map()四個(gè)函數(shù)的用法講解,需要的朋友可以參考下
    2016-05-05
  • Python爬蟲基礎(chǔ)之requestes模塊

    Python爬蟲基礎(chǔ)之requestes模塊

    這篇文章主要介紹了Python爬蟲基礎(chǔ)之requestes模塊,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python爬蟲的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • python調(diào)用接口的4種方式代碼實(shí)例

    python調(diào)用接口的4種方式代碼實(shí)例

    這篇文章主要介紹了python調(diào)用接口的4種方式代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Python3.6日志Logging模塊簡單用法示例

    Python3.6日志Logging模塊簡單用法示例

    這篇文章主要介紹了Python3.6日志Logging模塊簡單用法,結(jié)合實(shí)例形式分析了Python3.6環(huán)境下日志Logging模塊設(shè)置格式、文件流輸出相關(guān)操作技巧,需要的朋友可以參考下
    2018-06-06
  • Python技法-序列拆分詳解

    Python技法-序列拆分詳解

    Python中的任何序列(可迭代的對(duì)象)都可以通過賦值操作進(jìn)行拆分,包括但不限于元組、列表、字符串、文件、迭代器、生成器等。
    2021-10-10
  • Python中的None與 NULL(即空字符)的區(qū)別詳解

    Python中的None與 NULL(即空字符)的區(qū)別詳解

    這篇文章主要介紹了Python中的None與 NULL(即空字符)的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09

最新評(píng)論