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

Python Flask框架模板操作實例分析

 更新時間:2019年05月03日 10:56:03   作者:xuezhangjun  
這篇文章主要介紹了Python Flask框架模板操作,結(jié)合實例形式較為詳細(xì)的分析了Python Flask框架使用Jinja2模板步驟及相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了Python Flask框架模板操作。分享給大家供大家參考,具體如下:

模板

在前面的示例中,視圖函數(shù)的主要作用是生成請求的響應(yīng),這是最簡單的請求。實際上,視圖函數(shù)有兩個作用:處理業(yè)務(wù)邏輯和返回響應(yīng)內(nèi)容。在大型應(yīng)用中,把業(yè)務(wù)邏輯和表現(xiàn)內(nèi)容放在一起,會增加代碼的復(fù)雜度和維護成本。本節(jié)學(xué)到的模板,它的作用即是承擔(dān)視圖函數(shù)的另一個作用,即返回響應(yīng)內(nèi)容。 模板其實是一個包含響應(yīng)文本的文件,其中用占位符(變量)表示動態(tài)部分,告訴模板引擎其具體值需要從使用的數(shù)據(jù)中獲取。使用真實值替換變量,再返回最終得到的字符串,這個過程稱為“渲染”。Flask使用Jinja2這個模板引擎來渲染模板。Jinja2能識別所有類型的變量,包括{}。 Jinja2模板引擎,F(xiàn)lask提供的render_template函數(shù)封裝了該模板引擎,render_template函數(shù)的第一個參數(shù)是模板的文件名,后面的參數(shù)都是鍵值對,表示模板中變量對應(yīng)的真實值。

Jinja2官方文檔(http://docs.jinkan.org/docs/jinja2/

我們先來認(rèn)識下模板的基本語法:

{% if user %}
  {{ user }}
{% else %}
  hello!
<ul>
  {% for index in indexs %}
  <li> {{ index }} </li>
</ul>

通過修改一下前面的示例,來學(xué)習(xí)下模板的簡單使用:

@app.route('/')
def hello_itcast():
  return render_template('index.html')
@app.route('/user/<name>')
def hello_user(name):
  return render_template('index.html',name=name)

變量

在模板中{{ variable }}結(jié)構(gòu)表示變量,是一種特殊的占位符,告訴模板引擎這個位置的值,從渲染模板時使用的數(shù)據(jù)中獲取;Jinja2除了能識別基本類型的變量,還能識別{};

<span>{{mydict['key']}}</span>
<br/>
<span>{{mylist[1]}}</span>
<br/>
<span>{{mylist[myvariable]}}</span>

from flask import Flask,render_template
app = Flask(__name__)
@app.route('/')
def index():
  mydict = {'key':'silence is gold'}
  mylist = ['Speech', 'is','silver']
  myintvar = 0
  return render_template('vars.html',
              mydict=mydict,
              mylist=mylist,
              myintvar=myintvar
              )
if __name__ == '__main__':
  app.run(debug=True)

反向路由: Flask提供了url_for()輔助函數(shù),可以使用程序URL映射中保存的信息生成URL;url_for()接收視圖函數(shù)名作為參數(shù),返回對應(yīng)的URL;

如調(diào)用url_for('index',_external=True)返回的是絕對地址,在下面這個示例中是http://localhost:5000/。

如調(diào)用url_for('index',name='apple',_external=True)返回的是:
http://localhost:5000/index/apple

@app.route('/')
def hello_itcast():
  return render_template('index.html')
@app.route('/user/<name>')
def hello_user(name):
  return url_for('hello_itcast',_external=True)

自定義錯誤頁面:

from flask import Flask,render_template
@app.errorhandler(404)
def page_not_found(e):
  return render_template('404.html'), 404

過濾器:

過濾器的本質(zhì)就是函數(shù)。有時候我們不僅僅只是需要輸出變量的值,我們還需要修改變量的顯示,甚至格式化、運算等等,這就用到了過濾器。 過濾器的使用方式為:變量名 | 過濾器。 過濾器名寫在變量名后面,中間用 | 分隔。如:{{variable | capitalize}},這個過濾器的作用:把變量variable的值的首字母轉(zhuǎn)換為大寫,其他字母轉(zhuǎn)換為小寫。 其他常用過濾器如下:

safe:禁用轉(zhuǎn)義;

<p>{{ '<em>hello</em>' | safe }}</p>

capitalize:把變量值的首字母轉(zhuǎn)成大寫,其余字母轉(zhuǎn)小寫;

<p>{{ 'hello' | capitalize }}</p>

lower:把值轉(zhuǎn)成小寫;

<p>{{ 'HELLO' | lower }}</p>

upper:把值轉(zhuǎn)成大寫;

<p>{{ 'hello' | upper }}</p>

title:把值中的每個單詞的首字母都轉(zhuǎn)成大寫;

<p>{{ 'hello' | title }}</p>

trim:把值的首尾空格去掉;

<p>{{ ' hello world ' | trim }}</p>

reverse:字符串反轉(zhuǎn);

<p>{{ 'olleh' | reverse }}</p>

format:格式化輸出;

<p>{{ '%s is %d' | format('name',17) }}</p>

striptags:渲染之前把值中所有的HTML標(biāo)簽都刪掉;

<p>{{ '<em>hello</em>' | striptags }}</p>

語句塊過濾(不常用):

{% filter upper %}
  this is a Flask Jinja2 introduction
{% endfilter %}

自定義過濾器:

通過Flask應(yīng)用對象的add_template_filter方法,函數(shù)的第一個參數(shù)是過濾器函數(shù),第二個參數(shù)是過濾器名稱。然后,在模板中就可以使用自定義的過濾器。

def filter_double_sort(ls):
  return ls[::2]
app.add_template_filter(filter_double_sort,'double_2')

Web表單:

web表單是web應(yīng)用程序的基本功能。

它是HTML頁面中負(fù)責(zé)數(shù)據(jù)采集的部件。表單有三個部分組成:表單標(biāo)簽、表單域、表單按鈕。表單允許用戶輸入數(shù)據(jù),負(fù)責(zé)HTML頁面數(shù)據(jù)采集,通過表單將用戶輸入的數(shù)據(jù)提交給服務(wù)器。

在Flask中,為了處理web表單,我們一般使用Flask-WTF擴展,它封裝了WTForms,并且它有驗證表單數(shù)據(jù)的功能。

WTForms支持的HTML標(biāo)準(zhǔn)字段

WTForms常用驗證函數(shù)

使用Flask-WTF需要配置參數(shù)SECRET_KEY。

CSRF_ENABLED是為了CSRF(跨站請求偽造)保護。 SECRET_KEY用來生成加密令牌,當(dāng)CSRF激活的時候,該設(shè)置會根據(jù)設(shè)置的密匙生成加密令牌。

<form method='post'>
  <input type="text" name="username" placeholder='Username'>
  <input type="password" name="password" placeholder='password'>
  <input type="submit">
</form>

from flask import Flask,render_template
@app.route('/login',methods=['GET','POST'])
def login():
  if request.method == 'POST':
    username = request.form['username']
    password = request.form['password']
    print username,password
  return render_template('login.html',method=request.method)

配置參數(shù):

app.config['SECRET_KEY'] = 'silents is gold'
{{ form.username.label }}
{{ form.username() }}
{{ form.password.label }}
{{ form.password() }}
{{ form.submit() }}

我們通過登錄頁面來演示表單的使用。

#coding=utf-8
from flask import Flask,render_template,\
  flash,redirect,url_for,session
#導(dǎo)入WTF擴展包的Form基類
from flask_wtf import Form
from wtforms.validators import DataRequired,EqualTo
from wtforms import StringField,PasswordField,SubmitField
app = Flask(__name__)
#設(shè)置secret_key,防止跨站請求攻擊
app.config['SECRET_KEY'] = '2017'
#自定義表單類,繼承Form
class Login(Form):
  us = StringField(validators=[DataRequired()])
  ps = PasswordField(validators=[DataRequired(),EqualTo('ps2','error')])
  ps2 = PasswordField(validators=[DataRequired()])
  submit = SubmitField()
#定義視圖函數(shù),實例化自定義的表單類,
@app.route('/',methods=['GET','POST'])
def forms():
  #實例化表單對象
  form = Login()
  if form.validate_on_submit():
  #獲取表單數(shù)據(jù)
    user = form.us.data
    pswd = form.ps.data
    pswd2 = form.ps2.data
    print user,pswd,pswd2
    session['name'] = form.us.data
    flash(u'登陸成功')
    return redirect(url_for('forms'))
  else:
    print form.validate_on_submit()
  return render_template('forms.html',form=form)
if __name__ == "__main__":
  app.run(debug=True)

控制語句

常用的幾種控制語句:

模板中的if控制語句

@app.route('/user')
def user():
  user = 'dongGe'
  return render_template('user.html',user=user)

<html>
 <head>
   {% if user %}
    <title> hello {{user}} </title>
  {% else %}
     <title> welcome to flask </title>    
  {% endif %}
 </head>
 <body>
   <h1>hello world</h1>
 </body>
 </html>

模板中的for循環(huán)語句

 @app.route('/loop')
 def loop():
  fruit = ['apple','orange','pear','grape']
  return render_template('loop.html',fruit=fruit)

 <html>
 <head>
   {% if user %}
    <title> hello {{user}} </title>
  {% else %}
     <title> welcome to flask </title>    
  {% endif %}
 </head>
 <body>
   <h1>hello world</h1>
  <ul>
    {% for index in fruit %}
      <li>{{ index }}</li>
    {% endfor %}
  </ul>
 </body>
 </html>

宏:

類似于python中的函數(shù),宏的作用就是在模板中重復(fù)利用代碼,避免代碼冗余。

Jinja2支持宏,還可以導(dǎo)入宏,需要在多處重復(fù)使用的模板代碼片段可以寫入單獨的文件,再包含在所有模板中,以避免重復(fù)。

定義宏

{% macro input() %}
 <input type="text"
     name="username"
     value=""
     size="30"/>
{% endmacro %}

調(diào)用宏

{{ input()}}
#定義帶參數(shù)的宏
#調(diào)用宏,并傳遞參數(shù)
  <input type="password"
      name=""
      value="name"
      size="40"/>

模板繼承:

模板繼承是為了重用模板中的公共內(nèi)容。{% block head %}標(biāo)簽定義的元素可以在衍生模板中修改,extends指令聲明這個模板繼承自哪?父模板中定義的塊在子模板中被重新定義,在子模板中調(diào)用父模板的內(nèi)容可以使用super()。

 {% extends 'base.html' %}
 {% block content %}
  <h1> hi,{{ name }} </h1>
 {% for index in fruit %}
  <p> {{ index }} </p>
 {% endfor %}
 {% endblock %}

Flask中的特殊變量和方法:

在Flask中,有一些特殊的變量和方法是可以在模板文件中直接訪問的。

config 對象:

config 對象就是Flask的config對象,也就是 app.config 對象。

{{ config.SQLALCHEMY_DATABASE_URI }}

request 對象:

就是 Flask 中表示當(dāng)前請求的 request 對象。

{{ request.url }}

url_for 方法:

url_for() 會返回傳入的路由函數(shù)對應(yīng)的URL,所謂路由函數(shù)就是被 app.route() 路由裝飾器裝飾的函數(shù)。如果我們定義的路由函數(shù)是帶有參數(shù)的,則可以將這些參數(shù)作為命名參數(shù)傳入。

{{ url_for('index') }}
{{ url_for('post', post_id=1024) }}

get_flashed_messages方法:

返回之前在Flask中通過 flash() 傳入的信息列表。把字符串對象表示的消息加入到一個消息隊列中,然后通過調(diào)用 get_flashed_messages() 方法取出。

{% for message in get_flashed_messages() %}
  {{ message }}
{% endfor %}

希望本文所述對大家基于flask框架的Python程序設(shè)計有所幫助。

相關(guān)文章

  • Python的線程之線程同步

    Python的線程之線程同步

    這篇文章主要為大家介紹了Python線程同步,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • python 讀文件,然后轉(zhuǎn)化為矩陣的實例

    python 讀文件,然后轉(zhuǎn)化為矩陣的實例

    下面小編就為大家分享一篇python 讀文件,然后轉(zhuǎn)化為矩陣的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • python構(gòu)造IP報文實例

    python構(gòu)造IP報文實例

    這篇文章主要介紹了python構(gòu)造IP報文實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • python爬蟲破解字體加密案例詳解

    python爬蟲破解字體加密案例詳解

    這篇文章主要介紹了python爬蟲破解字體加密案例詳解,本文通過圖文實例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • 教你用Python實現(xiàn)自動提取并收集信息的功能

    教你用Python實現(xiàn)自動提取并收集信息的功能

    今天教大家怎么用Python實現(xiàn)自動提取并收集信息的功能,文中介紹的非常詳細(xì),有很多代碼示例,對正在學(xué)習(xí)python的小伙伴們很有幫助,需要的朋友可以參考下
    2021-05-05
  • Python爬取視頻時長場景實踐示例

    Python爬取視頻時長場景實踐示例

    這篇文章主要為大家介紹了Python獲取視頻時長場景實踐示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • Python常用編譯器原理及特點解析

    Python常用編譯器原理及特點解析

    這篇文章主要介紹了Python常用編譯器原理及特點解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • python卸載numpy出現(xiàn)WinError:拒絕訪問的解決方案

    python卸載numpy出現(xiàn)WinError:拒絕訪問的解決方案

    這篇文章主要介紹了python卸載numpy出現(xiàn)WinError:拒絕訪問的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • Python中隱藏的五種實用技巧分享

    Python中隱藏的五種實用技巧分享

    這篇文章主要和大家分享五個Python中隱藏的實用技巧,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Python有一定的幫助,感興趣的小伙伴可以學(xué)習(xí)一下
    2022-05-05
  • Django中Middleware中的函數(shù)詳解

    Django中Middleware中的函數(shù)詳解

    這篇文章主要介紹了Django中Middleware中的函數(shù)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07

最新評論