django-templates过滤器
常用内置过滤器:
过滤器会更改量或便签参数的值:
title过滤器:
{{ django|title }}
在下列context中
{'django': 'the web framework for perfectionists with deadlines'}
django变量值都是小写,经过过滤器渲染之后就会变成:
The Web Framework For Perfectionists With Deadlines
add加
把add后的参数加给value
例如:
{{ value|add:"2" }}
如果 value 为 4 ,则会输出 6 .
过滤器首先会强制把两个值转换成Int类型。如果强制转换失败, 它会试图使用各种方式吧两个值相加。它会使用一些数据类型 (字符串, 列表, 等等.) 其他类型则会失败. 如果转换失败,结果会变成一个空字符串
例如,我们使用下面的值
{{ first|add:second }}
first 是 [1, 2, 3] , second 是 [4, 5, 6] , 将会输出
[1, 2, 3, 4, 5, 6] .
警告
如果字符串可以被强制转换成int类型则会 summed,无法被转换,则和上面的第一个例子一样
addslashes
在引号前面加上斜杆。例如,用于在CSV中转义字符串。
例如:
{{ value|addslashes }}
如果 value 是 "I'm using Django" , 输出将变成 "I\'m using Django"
capfirst
大写变量的第一个字母。如果第一个字符不是字母,该过滤器将不会生效。
例如:
{{ value|capfirst }}
如果 value 是 "django" , 输出将变成 "Django" .
center
使"value"在给定的宽度范围内居中.
例如:
"{{ value|center:"15" }}"
如果 value 是 "Django" ,输出将是 “ Django t7> 。
cut切
移除value中所有的与给出的变量相同的字符串
例如:
{{ value|cut:" " }} {{ “You are not a Englishman” | cut:”not” }}
将输出‘’You are a Englishman“
date日期
根据给定格式对一个date变量格式化
例如:
{{ value|date:"D d M Y" }} {{ value|date }}
如果 value 是 datetime 对象(例如, datetime.datetime.now() 的结果),输出将分别是是字符串 'Wed 09 Jan 2008', ‘Jan 09 2008’ 。
default
如果value的计算结果为 False ,则使用给定的默认值。否则,使用该value。
例如:
{{ value|default:"nothing" }}
如果 value 为 "" (空字符串),则输出将为 nothing 。
default_if_none
如果(且仅当)value为 None ,则使用给定的默认值。否则,使用该value。
注意,如果给出一个空字符串,默认值将不被使用。如果要回退空字符串,请使用 default 过滤器。
例如:
{{ value|default_if_none:"nothing" }}
如果 value 为 None ,则输出将为字符串 “nothing”
dictsort
接受一个字典列表,并返回按参数中给出的键排序后的列表。
例如:
{{ value|dictsort:"name" }}
如果 value 为:
[ {'name': 'zed', 'age': 19}, {'name': 'amy', 'age': 22}, {'name': 'joe', 'age': 31}, ]
那么输出将是:
[ {'name': 'amy', 'age': 22}, {'name': 'joe', 'age': 31}, {'name': 'zed', 'age': 19}, ]
也可以用来做更复杂的事情:
{% for book in books|dictsort:"author.age" %} *{{ book.title }} ({{ book.author.name }}) {% endfor %}
如果books为:
[ {'title': '1984', 'author': {'name': 'George', 'age': 45}}, {'title': 'Timequake', 'author': {'name': 'Kurt', 'age': 75}, {'title': 'Alice', 'author': {'name': 'Lewis', 'age': 33}}, ]
输出将为:
* Alice (Lewis) * 1984 (George) * Timequake (Kurt
dictsortresvered
获取字典列表,并返回按照参数中给出的键按相反顺序排序的列表。这与上面的过滤器dictsort完全相同,但返回的值将是相反的顺序。
可分割
如果value可以被给出的参数整除,则返回 True
例如:
{{ value|divisibleby:"3" }}
如果 value 是 21 ,则输出将为 True 。
escape
使用形式:
{{ value | escape}}
意义:替换value中的某些字符,以适应HTML格式,包括:
< is converted to <
> is converted to >
’ (single quote) is converted to '
” (double quote) is converted to "
& is converted to &
escape仅仅在输出的时候才起作用,所以escape不能够用在链式过滤器的中间,
他应该总是最后一个过滤器,如果想在链式过滤器的中间使用,那么可以使用force_escape
first
返回列表中的第一项。
内建标签和过滤器
654
例如:
{{ value|first }}
如果 值 是列表 ['a', 'b', 'c'] ,输出将为 'a'
floatformat
使用形式:
{{ value|floatformat }}或者{{ value|floatformat:arg }}
arg可以是正数也可以是负数。没有参数的floatformat相当于floatformat:-1
(1)如果不带arg,那么引擎会四舍五入,同时最多只保留一位小数。
34.23234 {{ value|floatformat }} 34.2 34.00000 {{ value|floatformat }} 34 34.26000 {{ value|floatformat }} 34.3
(2)如果arg是正数,那么引擎会四舍五入,同时保留arg位的小数。
34.23234 {{ value|floatformat:3 }} 34.232 34.00000 {{ value|floatformat:3 }} 34.000 34.26000 {{ value|floatformat:3 }} 34.260
(3)如果arg是负数,那么引擎会四舍五入,如果有小数部分,那么保留arg位小数;否则,则没有任何小数部分。
34.23234 {{ value|floatformat:”-3” }} 34.232 34.00000 {{ value|floatformat:”-3” }} 34 34.26000 {{ value|floatformat:”-3” }} 34.26
get_digit
给定一个整数,返回所请求的数字,其中1是最右边的数字,2是第二个最右边的数
字等。返回无效输入的原始值(如果输入或参数不是整数,或参数小于1)。否
则,输出总是一个整数。
例如:
{{ value|get_digit:"2" }}
如果 value 为 123456789 ,则输出将为 8 。
join
使用字符串连接列表,例如Python的 str.join(list)
例如:
{{ value|join:" // " }}
如果 value 是列表 ['a', 'b', 'c'] /,输出将是字符串 “a // b //c“ 。
last
返回列表中的最后一个项目。
例如:
{{ value|last }}
如果列表为 ['a', 'b', 'c', 'd'] , 输出为"d" .
length
返回值的长度。这适用于字符串和列表。
例如:
{{ value|length }}
如果 value 是 ['a', 'b', 'c', 'd'] 或 "abcd" ,输出将为 4 。
length_is
如果值的长度是参数,则返回 True ,否则返回 False 。
例如:
{{ value|length_is:"4" }}
如果 value 是 ['a', 'b', 'c', 'd'] 或 "abcd" ,输出将为 True 。
linenumbers
显示带行号的文本。
例如:
{{ value|linenumbers }}
如果 value 为:
one
two
three
输出将是:
1\. one 2\. two 3\. three
lower
将字符串转换为全部小写。
例如:
{{ value|lower }}
如果 value 为 MAD 输出 mad 。
make_list
返回转换为列表的值。对于字符串,它是一个字符列表。对于整数,在创建列表之前将参数强制转换为unicode字符串。
例如:
{{ value|make_list }}
如果 value 是字符串 "Joel" ,输出将是列表 ['J', 'o' , 'e', 'l'] 。如果 value 是 123 ,则输出将是列表 ['1', '2', '3'] 。
phone2numeric
将电话号码(可能包含字母)转换为其等效数字。输入不必是有效的电话号码。这将很乐意转换任何字符串。
例如:
{{ value|phone2numeric }}
如果 value 为 800-COLLECT ,输出将为 800-2655328 。
random
返回给定列表中的随机项。
例如:
{{ value|random }}
如果列表是['a', 'b', 'c'],输出将是任意一个。
time
根据给定的格式格式化时间。
给定格式可以是预定义的 TIME_FORMAT ,也可以是与 date 过滤器相同的自定义格式。请注意,预定义的格式是与区域设置相关的。
例如:
{{ value|time:"H:i" }}
如果 value 等效于 datetime.datetime.now() ,则输出将为字符串 "01:23" 。
另外time过滤器只接受字符串中与时间相关的参数,而不是时间。
upper
将字符串转换为大写形式:
例如:
{{ value|upper }}
如果 value 是 “Joel ;,输出将为 “JOEL ” 。
urlencode
转义要在URL中使用的值。
例如:
{{ value|urlencode }}
If value is "http://www.example.org/foo?a=b&c=d" , the output will be"http%3A//www.example.org/foo%3Fa%3Db%26c%3Dd" .
可以提供包含不应该转义的字符的可选参数。
如果未提供,则'/'字符被假定为安全的。当所有字符应该转义时,可以提供空字符
串。例如:
{{ value|urlencode:"" }}
如果 value 为 "http://www.example.org/" ,输出将为 "http%3A%2F%2Fwww.example.org%2F" 。
posted on 2018-06-21 22:11 weilanhanf 阅读(341) 评论(0) 编辑 收藏 举报