亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python學習之flask基礎

發布時間:2020-08-10 21:43:19 來源:網絡 閱讀:157 作者:霍金181 欄目:編程語言

什么是Flask?
Flask是一個Web框架,就是提供一個工具,庫和技術來允許你構建一個Web應用程序.這個Web應用程序
可以是一些Web頁面,博客, wiki ,基于 Web 的日歷應用或商業網站。
Flask依賴模塊:
web服務網關接口(Python Web Server Gateway Interface,縮寫為WSGI
Werkzeug 一個WSGI工具包, 是為python語言定義的web服務器和web應用程序或框架之間的一
種簡單而通用的借口,其他語言也有類似的接口)
jinja2模板引擎

Flask的優勢

Flask屬于微框架( micro-framework )這一類別,微架構通常是很小的不依賴外部庫的框架.
框架很輕量
更新時依賴小
專注于安全方面的bug

第一個flask程序

from flask import Flask
app = Flask(__name__)  #導入Flask對象

@app.route('/')    #把修飾的函數注冊為路由
def hello_world():
    return 'Hello World!'

if __name__ == '__main__':
    app.run()

變量規則

要給url添加變量部分,可以把這些特殊的字符標記為<variable_name> 這部分將會作為命名參數傳遞到你的函數

from flask import  Flask
app = Flask(__name__)  #創建對象

@app.route('/')
def hello_world():
    return 'Hello World'

@app.route('/user/<username>')
def show_user_profile(username):
    # 顯示該用戶名的用戶信息
    return 'User %s'  % username

@app.route('/post/<int:post_id>')
def show_post(post_id):
    # 根據ID顯示文章,ID是整型數據
    return 'Post %d'  % post_id

if __name__ == '__main__':
    app.run()

運行程序將瀏覽器地址修改成 http://127.0.0.1:5000/user/歷史
則顯示:
python學習之flask基礎

構建url

如果flask能匹配url,那末你可以用url_info()來給指定的函數
構建url ,他接收函數名作為第一個參數,也接受對應url規則的變量部分的命名參數,未知變量部分會添加到url末尾作為查詢參數

from flask import Flask , url_for
app = Flask(__name__)

@app.route('/')
def hello_world():
    return 'Hello World!'

@app.route('/user/<username>')
def show_user_profile(username):
    # 顯示該用戶名的用戶信息
    return 'User %s' % username

@app.route('/post/<int:post_id>')
def show_post(post_id):
    # 根據ID顯示文章,ID是整型數據
    return 'Post %d' % post_id

@app.route('/url/')
def get_url():
    # 根據ID顯示文章,ID是整型數據
    return url_for('show_post',post_id=2)

if __name__ == '__main__':
    app.run(debug=True)

瀏覽器訪問url:
python學習之flask基礎

渲染模板

當用戶訪問程序的根地址時,我們的視圖函數會向客
戶端返回一行HTML代碼。然而,一個完整的HTML頁面往往需要幾十
行甚至上百行代碼,如果都寫到視圖函數里,那可真是個噩夢。這樣的
代碼既不簡潔也難于維護,正確的做法是把HTML代碼存儲在單獨的文
件中,以便讓程序的業務邏輯和表現邏輯分離,即控制器和用戶界面的
分離。
在動態Web程序中,視圖函數返回的HTML數據往往需要根據相應
的變量(比如查詢參數)動態生成。當HTML代碼保存到單獨的文件中
時,我們沒法再使用字符串格式化或拼接字符串的方式來在HTML代碼
中插入變量,這時我們需要使用模板引擎(template engine)。借助模
板引擎,我們可以在HTML文件中使用特殊的語法來標記出變量,這類
包含固定內容和動態部分的可重用文件稱為模板(template)。
模板引擎的作用就是讀取并執行模板中的特殊語法標記,并根據傳
入的數據將變量替換為實際值,輸出最終的HTML頁面,這個過程被稱
為渲染(rendering)。Flask默認使用的模板引擎是Jinja2,它是一個功
能齊全的Python模板引擎,除了設置變量,還允許我們在模板中添加if
判斷,執行for迭代,調用函數等,以各種方式控制模板的輸出。對于
Jinja2來說,模板可以是任何格式的純文本文件,比如HTML、XML、
CSV、LaTeX等

在該文件下創建templates文件夾,然后創建2個文件,分別命名為index.html和user.html 然后render.py 渲染這些模板

render.py

from flask import  Flask, render_template
app= Flask(__name__)

@app.route('/')
def hello_world():
    return render_template('index.html',name='經驗')

@app.route('/user/<username>')
def show_user_profile(username):
    # 顯示該用戶名的用戶信息
    return render_template('user.html', name=username)

if __name__ == '__main__':
    app.run(debug=True)

user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h2>hello, {{ name }}!</h2>

</body>
</html>

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h2>hello {{ name }} </h2>

</body>
</html>

瀏覽器:
python學習之flask基礎
python學習之flask基礎

模板語法

利用Jinja2這樣的模板引擎,我們可以將一部分的程序邏輯放到模
板中去。簡單地說,我們可以在模板中使用Python語句和表達式來操作
數據的輸出。但需要注意的是,Jinja2并不支持所有Python語法。而且
出于效率和代碼組織等方面的考慮,我們應該適度使用模板,僅把和輸
出控制有關的邏輯操作放到模板中。
Jinja2允許你在模板中使用大部分Python對象,比如字符串、列
表、字典、元組、整型、浮點型、布爾值。它支持基本的運算符號
(+、-、*、/等)、比較符號(比如==、!=等)、邏輯符號(and、
or、not和括號)以及in、is、None和布爾值(True、False)。
Jinja2提供了多種控制結構來控制模板的輸出,其中for和if是最常用
的兩種。在Jinja2里,語句使用{%...%}標識,尤其需要注意的是,在語
句結束的地方,我們必須添加結束標簽:
{% if user.bio %}
<i>{{ user.bio }}</i>
{% else %}
<i>This user has not provided a bio.</i>
{% endif %}

在這個If語句里,如果user.bio已經定義,就渲染{%if user.bio%}和
{%else%}之間的內容,否則就渲染{%else%}和{%endif%}之間的默認內容。末尾的{%endif%}用來聲明if語句的結束,這一行不能省略。
和在Python里一樣,for語句用來迭代一個序列:
<ul>
{% for movie in movies %}
<li>{{ movie.name }} - {{ movie.year }}</li>
{% endfor %}
</ul>

jinja2 模板引擎

1. 什么是Jinja2模板引擎?

  • 官方網址: http://docs.jinkan.org/docs/jinja2/
    Jinja2 是一個現代的,設計者友好的,仿照 Django 模板的 Python 模板語言。 它速度快,被廣泛使用,并且提供了可選的沙箱模板執行環境保證安全:
  • 1). python的Web開發中, 業務邏輯(實質就是視圖函數的內容)和頁面邏輯(html件)分開的, 使得代碼的可讀性增強, 代碼容易理解和維護;
  • 2). 模板渲染: 在html文件中,通過動態賦值 ,將重新翻譯好的html文件(模板引擎生效) 返回給用戶的過程。
  • 3). 其他的模板引擎: Mako, Template, Jinja2

2. Jinja2語法

Jinja2變量顯示語法:

{{ 變量名| 函數調用 }}

{{ name }}
{{ url_for() }}
{{ get_flshed_messages() }}

Jinja2變量內置過濾器:

"hello".lower()

  • 完整的過濾器查看位置: http://jinja.pocoo.org/docs/templates/#builtin-filters
safe            渲染值時不轉義
capitalize      把值的首字母轉換成大寫,其他字母轉換成小寫
lower           把值轉換成小寫形式
upper           把值轉換成大寫形式
title           把值中每個單詞的首字母都轉換成大寫
trim            把值的首尾空格去掉
striptags       渲染之前把值中所有的 HTML 標簽都刪掉

如何自定義過濾器?

for循環:

        {% for i in li%}
            xxx
        {% endfor %}

if語句

        {% if user == 'westos'%}
            xxxx
        {% elif user == 'hello' %}
            xxx
        {% else %}
            xxx
        {% endif%}

宏的操作

  • 相當于函數

    如何定義宏?

        <!--相當于python里面的定義函數, 后面使用的場景: 分頁顯示-->
        {%  macro render(id) %}
            <h2>hello world {{ id }}</h2>
        {% endmacro %}

如何調用宏?

    <!--調用定義好的宏(類似于python中的函數)-->
    {{ render(1) }}
    {{ render(2) }}
    {{ render(3) }}

include包含操作

  • 如何使用: {% include "06_inclued.html"%}

模板的繼承:

一般網站的導航欄和底部不會變化, 為了避免重復編寫導航欄信息;

  • 如何定義模板?
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>{% block title %}  {% endblock %}</title>
</head>
<body>
<div  > 這是導航欄</div>
{% block body %}
hello
{% endblock %}
<div  >這是底部</div>
</body>
</html>

- 如何繼承基模板?

{% extends  '06_base.html'%}
{% block title %}
    繼承案例
{% endblock %}
{% block body %}
<span >這是最新填的block內容</span>
{% endblockfrom flask  import  Flask, render_template

例:模板繼承py:

app = Flask(__name__)
@app.route('/')
def index():
    return  render_template('index.html')

@app.route('/bbs/')
def bbs():
    return  render_template('bbs.html')

@app.route('/blog/')
def blog():
    return  render_template('blog.html')
if __name__ == '__main__':
    app.run(port=5002) %}

base.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>{% block title %} {% endblock %}</title>
    <style>
        .nav{
            width: 100%;
            height: 50px;
            border: 1px solid red;
        }
        .left{
            width: 20%;
            border: 1px solid red;
            float: left;
            height: 100px;
        }

        .right{
            width: 79%;
             border: 1px solid green;
            float: left;
            height: 100px;
        }
    </style>
</head>
<body>

<div class="nav">
    導航欄
    <button>登錄</button>
    <button>注冊</button>
</div>

<div class="left">
    {% include 'left.html' %}

</div>

<div class="right">
    {% block body %}

    {% endblock %}
</div>

</body>
</html>

bbs.html

{% extends 'base.html' %}

{% block title %}

論壇
{% endblock %}
{% block body %}
<h2>bbs</h2>

blog.html

{% extends 'base.html' %}
{% block title %}

博客
{% endblock %}

{% block body %}
<h2>blog</h2>

index.html

{% extends 'base.html' %}

{% block title %}

主頁
{% endblock %}
{% block body %}
<h2>index</h2>

left.html

<ul>
    <li>新聞</li>
    <li>財經</li>
    <li>八卦</li>
<url>
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安新县| 毕节市| 浪卡子县| 台东市| 景谷| 定边县| 呼玛县| 那曲县| 从江县| 新安县| 城固县| 嘉定区| 磴口县| 辛集市| 阳谷县| 蓬溪县| 元江| 法库县| 长岛县| 香河县| 博客| 漳平市| 永泰县| 林甸县| 牙克石市| 民和| 将乐县| 萍乡市| 泽普县| 玉门市| 耒阳市| 嘉定区| 临洮县| 黑龙江省| 那曲县| 修武县| 平阳县| 察隅县| 洪泽县| 年辖:市辖区| 正宁县|