Flask基础(13)-->自定义过滤器
- 什么是过滤器?
过滤器的本质就是函数。有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化、运算等等,而在模板中是不能直接调用 Python 中的某些方法,那么这就用到了过滤器。
使用方式:
- 过滤器的使用方式为:变量名 | 过滤器。
{ {variable | filter_name(*args)}}
- 如果没有任何参数传给过滤器,则可以把括号省略掉
{ {variable | filter_name}}
链式调用
在 jinja2 中,过滤器是可以支持链式调用的,示例如下:
{ { "hello world" | reverse | upper }}
常见内建过滤器
字符串操作safe:禁用转义
{
{ 'hello' | safe }}capitalize:把变量值的首字母转成大写,其余字母转小写{
{ 'hello' | capitalize }}lower:把值转成小写{
{ 'HELLO' | lower }}upper:把值转成大写{
{ 'hello' | upper }}title:把值中的每个单词的首字母都转成大写{
{ 'hello' | title }}reverse:字符串反转{
{ 'olleh' | reverse }}format:格式化输出{
{ '%s is %d' | format('name',17) }}striptags:渲染之前把值中所有的HTML标签都删掉{
{ 'hello' | striptags }}truncate: 字符串截断{
{ 'hello every one' | truncate(9)}}列表操作first:取第一个元素{
{ [1,2,3,4,5,6] | first }}last:取最后一个元素{
{ [1,2,3,4,5,6] | last }}length:获取列表长度{
{ [1,2,3,4,5,6] | length }}sum:列表求和{
{ [1,2,3,4,5,6] | sum }}sort:列表排序{
{ [6,2,3,1,5,4] | sort }}语句块过滤{ % filter upper %} #一大堆文字#{% endfilter %}自定义模板 tem_filter.py
from flask import Flaskfrom flask import render_templateapp = 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_liapp.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_liif __name__ == '__main__': app.run(debug = True)
自定义模板 tem_filter.html
filter 自定义过滤器
{ { "123456789"|my_lireverse01 }}{ { "abcdefghijklm"|my_lireverse02 }}