一、add
将传进来的参数添加到原来的值上面。这个过滤器会尝试将“值”和“参数”转换成整形然后进行相加。如果转换成整形过程中失败了,那么将会将“值”和“参数”进行拼接。如果是字符串,那么会拼接成字符串,如果是列表,那么会拼接成一个列表。实例代码如下:

{{ value|add:""}}

如果value是等于4,那么结果将是6.如果value是等于一个普通的字符串,如‘abc’,那么结果将是abc2.

二、cut
移除值中所有指定的字符串。类似于python中的replace(args,"").实例代码:

{{ value|cut:""}}

三、date

将一个日期按照指定格式,格式化成字符串。实例代码如下:

# 数据
context = {
"today" : datetime.now()
}
# 模版
{{ value|date:'Y/m/d'}}

结果为:2019/12/30。其中Y代表的是四位数的年份,m代表两位数的月份,d代表的是两位数的日。还有其他的时间格式化的方法。

Y:四位数的年份
m:两位数的月份
n:月份,1-9前面没有0前缀
d:两位数字的天
j:天,1-9前面没有0前缀
g:小时,12小时格式的,1-9前面没有0前缀
h:小时,12小时格式的,1-9前面有0前缀
G:小时,24小时格式的,1-9前面没有0前缀
H:小时,24小时格式的,1-9前面有0前缀
i:分钟,1-9前面有0前缀
s:秒,1-9前面有0前缀

四、default过滤器
如果值被评估为False。比如[],"",None,{}等这些在if判断中为False的值,都会使用default过滤器提供的默认值。实例代码如下:

{{ value|default:"没有值"}}

当value是等于一个空的字符串。比如"",那么以上代码将会输出"没有值"

五、default_if_none过滤器
如果值是None,那么将会使用default_if_none提供的默认值。这个是和“default”有区别的,default是所有被评估为False的都会使用默认值。而default_if_none则只有在值等于None时才起作用。

{{ value|default_if_none:"该值为:None"}}

如果value是等于""即空字符串,那么上面的代码输出的也是空字符串;如果value是一个None值,以上代码才会输出:该值为:None。

六、first过滤器
返回列表、元组、字符串中的第一个元素。实例代码如下:

{{ value|first}}

如果value是[1,2,3],那么输出将会是1。

七、last过滤器
返回最后一个值,用法和first类似就不再赘述了。

八、floatformat过滤器
使用四舍五入的方式格式化一个浮点类型。如果这个过滤器没有传递任何参数。那么只会在小数点后保留一个小数,如果小数后面全是0,那么只会保留整数。当然也可以传递一个参数,标识具体保留几位小数。
1、如果没有传递参数

value:25.2548
模板:{{ value|folatformat }}
结果:25.3

2、传递参数

value:25.2548
模板:{{ value|folatformat:3 }}
结果:25.255

九、join过滤器

类似与python中的join,将列表、元组、字符串用指定的字符进行拼接。

value:[1,2,3]
模板:{{ value|join:"、"}}
结果:1、2、3

十、length过滤器:

获取一个列表、元组、字符串、字典的长度。

{{value|length}}

如果value是等于['1','e','r'],那么以上代码将会输出3,如果value值为None,则返回0。

十一、lower过滤器
将值中所有的字符全部转换成小写

{{ value|lower}}

十二、upper

将值中所有字母转换成大写,用法和lower一样。

十三、random过滤器
在被给的列表、字符串、元组中随机选择一个值。

{{value|random}}

如果value是等于['a','b','c'],那么会从中随机选择一个。

十四、safe过滤器
标记一个字符串是安全的。机会关掉这个字符串的自动转义。

{{value|safe}}

如果value是一个不包含任何特殊字符的字符串,比如<a>这种,那么以上代码就会把字符串正常的输入。如果value是一串html代码,那么以上代码会将这个html代码渲染到浏览器中。

十五、slice过滤器
类似与python中的切片操作。

{{some_list|slice:"3:"}}

以上代码将会将some_list从3开始做切片操作。

十六、stringtags过滤器:
删除字符串中所有的html标签。

{{value|striptags}}

如果value是<span>hello world</span>,那么以上代码将会输出hello world。

十七、truncatechars过滤器:
如果给定的字符串长度超过了过滤器指定的长度。那么将会进行切割,并且会拼接3个点作为省略号。实例代码如下:

{{ value|truncatechars:5}}

如果value是等于"阳光明媚的天气",那么输出的结果为"阳光..."。注意3个点也占字符。

十八、truncatechars_html过滤器:
类似于truncatechars,只不过是不会切割HTML标签。

{{ value|truncatechars_html:5}}

如果value是<p>阳光明媚的天气</p>,那么输出是<p>阳光...</p>

django 模版内置的过滤器的更多相关文章

  1. django的内置信号

    Model singnalspre_init 在model执行构造方法之前自动触发post_init django的model在执行构造方法之后,自动触发pre_save django的对象保存之前, ...

  2. Django的内置登录、退出、修改密码方法

    Django中内置的登录.退出.修改密码方法. 1.url.py中使用django.contrib.auth中的views函数,django.views.generic中的TemplateView函数 ...

  3. django的内置分页

    本节内容 自定义一个简单的内置分页 Django内置分页 Django内置分页扩展(继承) 自定义内置组件 自定义一个简单的内置分页 先用django自己自定制一个简单的内置分页,大概掌握内置分页的底 ...

  4. Django 使用 内置 content-type

    django内置的content-type组件, 记录了项目中所有model元数据的表 可以通过一个ContentType表的id和一个具体表中的id找到任何记录,及先通过ContenType表的id ...

  5. Django扩展内置User类

    内置User类 使用内置User可以方便实现登录验证,利用Admin管理界面还可以方便添加.删除.修改用户. 一个内置的User类定义了以下字段: username: 用户名 password: 密码 ...

  6. Django常用内置过滤器

    1.add 此过滤器将首先尝试将两个值强制为整数.如果失败,它会尝试将值一起添加.这将工作在一些数据类型(字符串,列表等)和失败在其他人.如果失败,结果将是一个空字符串. {{ value | add ...

  7. django+mongodb 内置用户控制

    0x01 项目:django2.1 数据库:mongodb 这是一个很蛋疼的组合 mongodb并非官方支持使用的数据库,这意味着要使用user group permissions等进行用户和权限控制 ...

  8. Django ContentType内置组件

    一.引出问题 假如有这两张表,它们中的课程可能价格不一样.周期不一样.等等...不一样...,现在有一张价格策略表,怎么就用一张表报保存它们之间不同的数据呢? 可能你会这样: 确实是行!但是,如果有很 ...

  9. Django Form 内置字段

    常用字段: Field required=True, 是否允许为空 widget=None, HTML插件 label=None, 用于生成Label标签或显示内容 initial=None, 初始值 ...

随机推荐

  1. Linux创建连接命令 ln -s创建软连接

    ln -s 是linux中一个非常重要命令,一定要熟悉.它的功能是为某一个文件在另外一个位置建立一个同不的链接,这个命令最常用的参数是-s, 具体用法是:ln -s 源文件 目标文件. 当 我们需要在 ...

  2. PTA点赞狂魔

     点赞狂魔 (25 分) 微博上有个“点赞”功能,你可以为你喜欢的博文点个赞表示支持.每篇博文都有一些刻画其特性的标签,而你点赞的博文的类型,也间接刻画了你的特性.然而有这么一种人,他们会通过给自己看 ...

  3. json 字符串 <----> json 对象

    一,字符串 -->JSON对象 1,转换函数 JSON.parse(json_str): 2,$.parseJSON(json_str):  用的是 jquery 的插件  所以需要引入 jq. ...

  4. spring security 方法权限使用

    前面我们讲过了使用<security:intercept-url>配置url的权限访问,下面我们讲解一下基于方法的权限使用默认情况下, Spring Security 并不启用方法级的安全 ...

  5. POJ-3821-Dining (拆点网络流)

    这题为什么不能用 左边放食物,中间放牛,后面放水? 原因很简单,假设一头牛喜欢两个食物AB和两种水AB. 此时可以从一个食物A,走到牛A,再走到水A. 但是还可以有另一条路,从另一个食物B,走到该牛A ...

  6. 洛谷P1346 电车(需要稍加思索的最短路)

    题目描述 在一个神奇的小镇上有着一个特别的电车网络,它由一些路口和轨道组成,每个路口都连接着若干个轨道,每个轨道都通向一个路口(不排除有的观光轨道转一圈后返回路口的可能).在每个路口,都有一个开关决定 ...

  7. sqlserver数据库中char、varchar、text与nchar、nvarchar、ntext数据类型使用详解

    很多开发者进行数据库设计的时候往往并没有太多的考虑char, varchar类型,有的是根本就没注意,因为存储价格变得越来越便宜了,忘记了最开始的一些基本设计理论和原则,这点让我想到了现在的年轻人,大 ...

  8. pip源、搭建虚拟环境、git

    一.pip源 1.1 介绍 1.采用国内源,加速下载模块的速度2.常用pip源:-- 豆瓣:https://pypi.douban.com/simple-- 阿里:https://mirrors.al ...

  9. 【layui】提交表单

    1 <script type="text/javascript"> layui.use(['form', 'layer', 'jquery'], function () ...

  10. 【SSM】日志框架 logback

    logback.xml <?xml version="1.0" encoding="UTF-8" ?> <configuration scan ...