首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Python Flask 编程 | 连载 07 - Jinja2 语法

Python Flask 编程 | 连载 07 - Jinja2 语法

作者头像
RiemannHypothesis
发布于 2022-09-26 08:43:14
发布于 2022-09-26 08:43:14
1.6K00
代码可运行
举报
文章被收录于专栏:ElixirElixir
运行总次数:0
代码可运行

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第9天,点击查看活动详情

一、Jinja2 语法

模板标签

for循环表达式

在页面中展示列表或者字典数据时常常会用到 for循环,将列表中的每个数据迭代并进行展示,模板中 for 循环 的写法如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{% for key, value in data.items() %}
    {{ key }}: {{ value }}
{% else %}
    {# 展示字典为空的提示
{% endfor %}

修改 tag 视图函数,增加一个含有字典数据的变量。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@app.route('/tag')
def tag():
    name='stark'

    heros = [
        {'name': 'stark', 'address': 'New York'},
        {'name': 'thor', 'address': 'Asgard'},
        {'name': 'strange', 'address': 'New York'},
        {'name': 'peter', 'address': 'New York Queens'},
    ]
    return render_template('tag.html', name=name, heros=heros)

在 tag.html 的 body 标签中增加 for循环 表达式

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<h2>for循环的使用</h2>
<ul>
    {% for hero in heros %}
        <li>{{ hero.name }}: {{ hero.address }}</li>
    {% else %}
        <li>NO Data</li>
    {% endfor %}
</ul>

在浏览器中访问 /tag

for 循环 中包含了一个 loop 对象,即指代这次迭代,loop 对象中包含了一些属性如下:

变量

说明

loop.index

当前循环迭代次数从1开始

loop.index0

当前循环迭代次数从0开始

loop.revindex

循环从1开始到结束需要迭代的次数

loop.revindex0

循环从0开始到结束需要迭代的次数

loop.first

如果是第一次迭代,该变量的值为True,否则为False

loop.last

如果是最后一次迭代,该变量的值为True,否则为False

loop.length

迭代序列的长度

loop.cycle

在一串序列间取值的辅助函数

修改 tag.html,在 head 标签中增加样式并在 body 标签中使用 loop 对象的属性。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<head>
    <style>
        .yankee {
            background: yellow;
        }

        .zulu {
            background: red;
        }
    </style>
</head>
<body>
    <h2>for循环中loop对象的使用</h2>
    {% for hero in heros %}
        <p class="{{ loop.cycle('yankee', 'zulu')}}">
            当前是第{{ loop.index }}个元素,索引为{{ loop.index0 }},共{{ loop.length }}个元素
            {% for key, value in hero.items() %}
                {{ key }}: {{ value }}
            {% endfor %}
        </p>
    {% endfor %}
<body>

再次访问 /tag

Python 代码中进行 for 循环 时可以通过 continue 或者 break 关键字来跳过当前循环或者停止循环,但是在模板中是没有 continuebreak 关键字的。

在 tag.html 中增加的 for循环,增加条件判断,当符合条件时使用 break 关键字结束循环。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<h2>for循环中使用break关键字</h2>
{% for hero in heros %}
    <p class="{{ loop.cycle('yankee', 'zulu')}}">
        当前是第{{ loop.index }}个元素,索引为{{ loop.index0 }},共{{ loop.length }}个元素
        {% for key, value in hero.items() %}
            
            {# 符合条件时退出循环,这里的loop.index是循环字典时的loop,注意与上面循环列表的loop进行区分 #}
            {% if loop.index == 2 %}
                {% break %}
            {% endif %}
            {{ key }}: {{ value }}
        {% endfor %}
    </p>
{% endfor %}

此时页面报错出现未知的标签 break,说明在模板中是无法通过 break 来结束循环的。应在模板中添加扩展之后才可以 breakcontinue关键字。

在 app.py 中添加使用扩展的代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
app = Flask(__name__)
# 为模板引擎添加扩展,支持break/continue关键字
app.jinja_env.add_extension('jinja2.ext.loopcontrols')

再次访问 /tag

这一次添加扩展之后,模板中 break 关键字生效。

使用标签渲染出来的 html 代码多了很多空行,这是会占用带宽的,去除这些空行有利于提升性能。

% 前后添加 - 可以删除空行。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<h2>for循环中使用break关键字</h2>
{% for hero in heros -%}
    <p class="{{ loop.cycle('yankee', 'zulu')}}">
        当前是第{{ loop.index }}个元素,索引为{{ loop.index0 }},共{{ loop.length }}个元素
        {%- for key, value in hero.items() -%}

            {%- if loop.index == 2 -%}
                {% break %}
            {%- endif -%}
            {{ key }}: {{ value }}
        {%- endfor -%}
    </p>
{% endfor %}

再次查看页面的源代码,空格已被删除。

模板中的赋值

在模板中可以通过 set 关键字在 {%%} 中定义一个变量并进行赋值操作,set 关键字常与 with 关键字搭配使用,通过 with 关键字定义代码块,使得 set 关键字定义的变量只能在 with 指定的代码块使用。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{% with %}
{% set classname='zulu' %}
{{ classname }}
{% endwith %}

在 tag.html 中增加如下内容:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<h2>setwith关键字的使用</h2>
{% with %}
    {% set classname='zulu' %}
    {# 在with代码块中定义了classname的值为zulu,背景色会变成红色 #}
    <p class="{{ classname }}">使用classname变量的p标签</p>
{% endwith %}
{# 在with代码块外,classname没有值 #}
<p class="{{ classname }}">使用classname变量的p标签</p>

在浏览器中访问 /tag

模板标签特殊字符的转义

模板中的 {{}}{%%} 来进行渲染操作,那么如何在模板中显示这些特殊字符呢?

第一种方式是将这些特殊字符普通字符串处理;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<h2>模板语法中的特殊字符显示</h2>
<p>第一种方式:{{ '{{ value }}, {% if value=="stark" %}' }}</p>

当代码比较多的时候,这种方式处理起来就比较繁琐。

第二种方式是使用 raw 标签;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<h2>模板语法中的特殊字符显示</h2>
<p>第一种方式:{{ '{{ value }}, {% if value=="stark" %}' }}</p>
<p>第二种方式:
    {% raw %}
    {{ value }}, {% if value=="stark" %}
    {% endraw %}
</p>

推荐使用第二种方式。

模板的全局函数

全局函数可以在模板中直接使用,常用的全局函数有:

  • range(),返回一系列连续增加的整数
  • dict(),创建字典
  • cycler(),用于 CSS 类名循环
  • joiner(),字符串拼接
  • url_for(),URL 解析,用于静态文件地址解析、链接跳转地址解析
  • get_flashed_message():会话消息,如登录成功或者更新成功的提示

在 templates 目录下新建一个 global_funcs.html,内容如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8"/>
    <title>全局函数的使用</title>
</head>
<body>
    <h2>全局函数range()函数的使用</h2>
    {% for i in range(7) %}
        <p>{{ i }}</p>
    {% endfor %}
</body>
</html>

在 app.py 中新建一个视图函数 global_funcs,返回 global_funcs.html 页面。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@app.route('/global_funcs')
def gloab_funcs():

    return render_template('global_funcs.html')

模板中的 range 函数返回了从 0~6 之间的整数。

在 global_funcs.html 中新增 cycler 函数;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<head>
    <meta charset="UTF-8"/>
    <title>全局函数的使用</title>
    <style>
        .zulu {
            color: red;
        }

        .yankee {
            color: aqua;
        }
    </style>
</head>
<body>
    <h2>全局函数cycle()函数的使用</h2>
    {% set class_name = cycler('zulu', 'yankee') %}
    {% for i in range(7) %}
        <p class={{ class_name.next() }}>{{ i }}</p>
    {% endfor %}
</body>

cycle 函数轮询 zulu 和 yankee 两个 CSS 属性,给 range 函数生成的 7 个 p 标签填了这两个 CSS 属性。

在模板中使用 url_for 进行解析静态文件地址,新建一个 static 文件夹,并在该文件夹下新增一个 CSS 文件。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
body {
    background-color: cadetblue;
}

h2 {
    color: white;
}

在 global_funcs.html 页面中的 head 增加引用。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<head>
    <!--其余代码不变-->
    <link rel="stylesheet" href="{{ url_for('static', filename='style.css') }}">
</head>

样式发生改变,url_for 函数可以正确解析出 CSS 的路径。如果没有生效,清除缓存即可。

url_for 还可以根据 url name 解析出 url 映射地址。

使用 url_for 首先要给 url 设置一个 url name,在 app.py 中增加代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@app.route('/index')
def show_html():
    # 其余代码保持不变

# 给url设置一个name
app.add_url_rule('/index', 'index')

修改 global_funcs.html 页面内容如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<body>
    <h2>全局函数url_for的使用</h2>
    <a href="{{ url_for('index') }}">INDEX</a>
</body>

访问 /global_funcs

点击INDEX,即可跳转到 /index 页面。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-06-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
tensorflow | 维度转换
学习维度转换 shape 计算维度 tf.shape(input,name = None) 案例1 a = tf.constant([i for i in range(20)],shape =[2,2,5]) with tf.Session() as sess: print (sess.run(tf.shape(a))) 结果:[2 2 5] size 计算元素个数 tf.size(input,name = None) 案例2 a = tf.constant([i for i in range
努力在北京混出人样
2018/05/14
1.2K0
TensorFlow基础:常量
例如 tf.zeros,tf.ones,tf.zeros_like,tf.diag ...
lyhue1991
2020/07/20
3640
通俗易懂!使用Excel和TF实现Transformer!
中文词表:[机、器、学、习] 英文词表[deep、machine、learning、chinese]
石晓文
2019/06/17
4860
通俗易懂!使用Excel和TF实现Transformer!
斯坦福tensorflow教程(二) tensorflow相关运算1.认识下TensorBoard2.常量op3. 数学运算数据类型
1.认识下TensorBoard TensorFlow不仅是一个软件库,而是一整套包括TensorFlow、TensorBoard、Tensor Serving在内的软件包。为了更大程度地利用TensorFlow,我们应该了解如何将它们串联起来应用。在和一部分,我们来探索下TensorBoard。 TensorBoard是一个图(graph)可视化软件,在(安装TensorFlow的时候会默认安装)。下面是谷歌的介绍: The computations you'll use TensorFlow for
致Great
2018/06/14
8100
基于TensorFlow的深度学习系列教程 2——常量Constant
在tensorflow中,数据分为几种类型: 常量Constant、变量Variable、占位符Placeholder。其中:
用户1154259
2019/07/02
7650
tensorflow编程: Constants, Sequences, and Random Values
  注意: start 和 stop 参数都必须是 浮点型;     取值范围也包括了 stop; tf.lin_space 等同于 tf.linspace。
JNingWei
2018/09/28
4510
TensorFlow2 一小时学会基本操作 2
https://iamarookie.blog.csdn.net/article/details/117651502
润森
2022/09/22
3520
TensorFlow2 一小时学会基本操作 2
tensorflow编程: Running Graphs
  A class for running TensorFlow operations.   这是一个类,执行 tensorflow 中的 op 。它里面定义了 run()、extend()、close()、__init__() 等方法。
JNingWei
2018/09/28
5530
使用一维数据构造简单卷积神经网络
神经网络对于一维数据非常重要,时序数据集、信号处理数据集和一些文本嵌入数据集都是一维数据,会频繁的使用到神经网络。我们在此利用一组一维数据构造卷积层-最大池化层-全连接层的卷积神经网络。希望给大家使用CNN处理一维数据一些帮助。
演化计算与人工智能
2020/08/14
1.7K0
教程 | 维度、广播操作与可视化:如何高效使用TensorFlow
选自GitHub 机器之心编译 参与:Nurhachu Null、李泽南 本文从 Tensorflow 基础、理解静态维度和动态维度、广播操作(Broadingcast 的好处和坏处)、使用 Python 操作的原型内核和先进的可视化等几个方面详细梳理如何高效使用TensorFlow。 Tensorflow 基础 TensorFlow 和其他诸如 numpy 之类的数学计算库的根本区别在于:在 TensorFlow 中,运算操作是符号化的。这是一个强大的思想,它能够让 TensorFlow 做任何事情(例如
机器之心
2018/05/09
1.5K0
Tensorflow技术点整理(二)
这里跟PyTorch不同的是序号定义的不同,PyTorch是上下定义位置,而Tensorflow是左右定义位置。
算法之名
2022/03/24
4670
Tensorflow技术点整理(二)
tensorflow运行mnist的一些
最近在tensorflow环境下用CNN来实现mnist,里面设计了一些tensorflow的函数,在之后的学习中肯定会经常使用,因此记录整理下来。
py3study
2020/01/20
5330
TensorFlow2.0(1):基本数据结构——张量
TensorFlow2.0版本已经发布,虽然不是正式版,但预览版都发布了,正式版还会远吗?相比于1.X,2.0版的TensorFlow修改的不是一点半点,这些修改极大的弥补了1.X版本的反人类设计,提升了框架的整体易用性,绝对好评!
Ai学习的老章
2019/12/23
1.6K0
使用二维数据构造简单卷积神经网络
使用二维数据构造简单卷积神经网络 图像和一些时序数据集都可以用二维数据的形式表现,我们此次使用随机分布的二位数据构造一个简单的CNN—网络卷积-最大池化-全连接 参考代码 # Implementing Different Layers # --------------------------------------- # # We will illustrate how to use different types # of layers in TensorFlow # # The layers of i
演化计算与人工智能
2020/08/14
8680
张量拼接_调整维度_切片
tf.concat的作用主要是将向量按指定维连起来,其余维度不变;而1.0版本以后,函数的用法变成:
狼啸风云
2019/07/01
1.3K0
TF入门02-TensorFlow Ops
我们首先介绍一下TensorBoard的使用,然后介绍TensorFlow的基本ops,之后介绍张量的数据类型,最后介绍一下如何将自己的输入导入模型。
公众号-不为谁写的歌
2020/07/23
1.7K0
[阿里DIN]从模型源码梳理TensorFlow的形状相关操作
本文基于阿里推荐 DIN 和 DIEN 代码,梳理了下深度学习一些概念,以及TensorFlow中的相关实现。
罗西的思考
2020/11/24
9180
【tensorflow2.0】张量的结构操作
张量数学运算主要有:标量运算,向量运算,矩阵运算。另外我们会介绍张量运算的广播机制。
西西嘛呦
2020/08/26
2.3K0
[阿里DIN] 从模型源码梳理TensorFlow的乘法相关概念
本文基于阿里推荐 DIN 和 DIEN 代码,梳理了下深度学习一些概念,以及TensorFlow中的相关实现。
罗西的思考
2020/11/11
1.8K0
推荐阅读
相关推荐
tensorflow | 维度转换
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档