Flask基础(14)

Stella981
• 阅读 662

Flask基础(13)-->自定义过滤器

  • 什么是过滤器?

    过滤器的本质就是函数。有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化、运算等等,而在模板中是不能直接调用 Python 中的某些方法,那么这就用到了过滤器。

使用方式:

  • 过滤器的使用方式为:变量名 | 过滤器。

    {{variable | filter_name(*args)}}
    
  • 如果没有任何参数传给过滤器,则可以把括号省略掉

    {{variable | filter_name}}
    

    链式调用

    在 jinja2 中,过滤器是可以支持链式调用的,示例如下:

    {{ "hello world" | reverse | upper }}
    
    常见内建过滤器
    
    
    字符串操作
    safe:禁用转义
    <p>{{ '<em>hello</em>' | safe }}</p>
    capitalize:把变量值的首字母转成大写,其余字母转小写
    <p>{{ 'hello' | capitalize }}</p>
    lower:把值转成小写
    <p>{{ 'HELLO' | lower }}</p>
    upper:把值转成大写
    <p>{{ 'hello' | upper }}</p>
    title:把值中的每个单词的首字母都转成大写
    <p>{{ 'hello' | title }}</p>
    reverse:字符串反转
    <p>{{ 'olleh' | reverse }}</p>
    format:格式化输出
    <p>{{ '%s is %d' | format('name',17) }}</p>
    striptags:渲染之前把值中所有的HTML标签都删掉
    <p>{{ '<em>hello</em>' | striptags }}</p>
    truncate: 字符串截断
    <p>{{ 'hello every one' | truncate(9)}}</p>
    列表操作
    first:取第一个元素
    <p>{{ [1,2,3,4,5,6] | first }}</p>
    last:取最后一个元素
    <p>{{ [1,2,3,4,5,6] | last }}</p>
    length:获取列表长度
    <p>{{ [1,2,3,4,5,6] | length }}</p>
    sum:列表求和
    <p>{{ [1,2,3,4,5,6] | sum }}</p>
    sort:列表排序
    <p>{{ [6,2,3,1,5,4] | sort }}</p>
    语句块过滤
    {% filter upper %}
        #一大堆文字#
    {% endfilter %}
    

    **
    自定义模板 tem_filter.py
    **

    from flask import Flask
    from flask import render_template
    
    app = Flask(__name__)
    
    @app.route('/')
    def demo1():
        return render_template("tem_filter.html")
    # 方法一:通过注册的方式定义过滤器
    # add_template_filter的底层函数 self.jinja_env.filters[name or f.__name__] = f
    #  add_template_filter参数可以理解为:通过自定义过滤器名字my_lireverse找到过滤器的引用do_listreverse,然后通过引用启动过滤器
    def do_listreverse(li):
        temp_li = list(li)
        temp_li.reverse()
        return temp_li
    app.add_template_filter(do_listreverse,"my_lireverse01")
    
    # 方法二:装饰器实现过滤器dolistreverse
    # 装饰器实现过滤器就比较好理解了,模板页直接通过参数my_lireverse02寻找
    # do_listreverse函数,最终将过滤结果返回给模板页的调用处
    @app.template_filter("my_lireverse02")
    def do_listreverse(li):
        # 通过原列表创建一个新列表
        temp_li = list(li)
        # 将新列表进行返转
        temp_li.reverse()  
        return temp_li
    
    if __name__ == '__main__':
        app.run(debug = True)
    

    **自定义模板 tem_filter.html

    **

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>filter</title>
    </head>
    <body>
    <h4>自定义过滤器</h4>
    {{ "123456789"|my_lireverse01 }}<br/>
    {{ "abcdefghijklm"|my_lireverse02 }}
    </body>
    </html>
    
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Easter79 Easter79
3年前
springcloud gateway高级功能之根据参数自定义路由Predicate
背景我们使用了springcloudgateway作为也给路由转发功能,由于历史遗留问题,不仅仅需要根据path转发,还需要根据get或者post中的参数进行转发解决方案这里我们使用自定义的Predicate进行转发简介这里简单介绍下相关术语(1)Filter(过滤器):和Zuul的过滤器在概念上类似,可以使
Easter79 Easter79
3年前
SpringMVC的拦截器(Interceptor)和过滤器(Filter)的区别与联系
一简介(1)过滤器:依赖于servlet容器。在实现上基于函数回调,可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的是用来做一些过滤操作,获取我们想要获取的数据,比如:在过滤器中修改字符编码;在过滤器中修改HttpServletRequest的一些参数,包括:过滤低俗文字、危险字符等关于
Stella981 Stella981
3年前
SpringBoot 的过滤器 Filter 配置的三种方式
SpringBoot过滤器配置有三种方式1\.@ServletComponentScan@WebFilter,可配置过滤路径,但没有顺序(顺序是由过滤器命名决定)在启动类上使用 @ServletComponentScan,在过滤器类上使用 @WebFilter(urlPatterns{"/test/path"})
Stella981 Stella981
3年前
Google布隆过滤器与Redis布隆过滤器详解
一、什么是布隆过滤器?布隆过滤器可以用来判断一个元素是否在一个集合中。它的优势是只需要占用很小的内存空间以及有着高效的查询效率。对于布隆过滤器而言,它的本质是一个位数组:位数组就是数组的每个元素都只占用1bit,并且每个元素只能是0或者1布隆过滤器除了一个位数组,还有K个哈希函数。当一个元素加入布隆过滤器中的时候,会进行如下操作:
Stella981 Stella981
3年前
Django框架 之 模板语言
浏览目录标签过滤器一、标签Tags1、普通变量普通变量用{{}}变量名由数字、字母、下划线组成点.在模板语言中用来获取对象相应的属性值示例:{取variable中的第一个参数}{{variable.0}}{
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
京东云开发者 京东云开发者
2个月前
一文理解布隆过滤器和布谷鸟过滤器
作者:京东保险王奕龙最近在大促中使用到了布隆过滤器,所以本次借着机会整理下相关内容,并了解了布谷鸟过滤器,希望对后续学习的同学有启发\布隆过滤器布隆过滤器是概率性数据结构,用于检查元素是否存在集合中。布隆过滤器并不存储集合中的所有元素,而是存储元素的哈希表