标题:Django中的内建的模板标签和过滤器(filter) 出处:Husw!OnRoad 在路上 时间:Sat, 11 Jun 2011 22:30:37 +0000 作者:我就是个世界 地址:https://www.husw.net/blog/Django-built_in-template-tags-and-filters-Reference/ 内容: Django中的内建的模板标签和过滤器 Django Built-in template tags and filters¶ https://docs.djangoproject.com/en/dev/ref/templates/builtins/ http://djangobook.py3k.cn/appendixF/index.html 第四章列出了许多的常用内建模板标签和过滤器。然而,Django自带了更多的内建模板标签及过滤器。 这章附录列出了截止到编写本书时,Django所包含的各个内建模板标签和过滤器,但是,新的标签是会被定期地加入的。 对于提供的标签和过滤器,最好的参考就是直接进入你的管理界面。Django的管理界面包含了一份针对当前站点的所有标签和过滤器的完整参考。想看到它的话,进入你的管理界面,单击右上角的Documentation(文档)链接。 内建文档中的“标签和过滤器”小节阐述了所有内建标签(事实上,本附录中的标签和过滤器参考都直接来自那里)和所有可用的定制标签库。 考虑到那些没有管理站点可用的人们,这里提供了常用的标签和过滤器的参考。由于Django是可高度定制的,管理界面中的那些可用的标签和过滤器的参考可认为是最可信的。 [b]内建标签参考[/b] block 定义一个能被子模板覆盖的区块。参见第四章“模板继承”一节查看更多信息。 comment 模板引擎会忽略掉 {% comment %} 和 {% endcomment %} 之间的所有内容。 cycle 轮流使用标签给出的字符串列表中的值。 在一个循环内,轮流使用给定的字符串列表元素: {% for o in some_list %} ... {% endfor %} 在循环外,在你第一次调用时,给这些字符串值定义一个不重复的名字,以后每次只需使用这个名字就行了: ... ... ... 你可以使用任意数量的用逗号分隔的值。注意不要在值与值之间有空格,只是一个逗号。 debug 输出完整的调试信息,包括当前的上下文及导入的模块信息。 extends 标记当前模板扩展一个父模板。 这个标签有两种用法: {% extends "base.html" %} (带引号) 直接使用要扩展的父模板的名字 "base.html" 。 {% extends variable %} 用变量 variable 的值来指定父模板。如果变量是一个字符串,Django会把字符串的值当作父模板的文件名。如果变量是一个 Template 对象,Django会把这个对象当作父模板。 参看第四章更多应用实例。 filter 通过可变过滤器过滤变量的内容。 过滤器也可以相互传输,它们也可以有参数,就像变量的语法一样。 看这个用法实例: {% filter escape|lower %} This text will be HTML-escaped, and will appear in all lowercase. {% endfilter %} firstof 输出传入的第一个不是 False 的变量,如果被传递变量都为 False ,则什么也不输出。 看这个用法实例: {% firstof var1 var2 var3 %} 这等同于如下内容: {% if var1 %} {{ var1 }} {% else %}{% if var2 %} {{ var2 }} {% else %}{% if var3 %} {{ var3 }} {% endif %}{% endif %}{% endif %} for 轮询数组中的每一元素。例如显示一个指定的运动员的序列 athlete_list : 你也可以逆向遍历一个列表 {% for obj in list reversed %} 。 for 循环设置了许多循环中可用的变量(见表F-1)。 表F-1. {% for %}循环中的可用变量 变量名 描述 forloop.counter 当前循环次数(索引最小为1)。 forloop.counter0 当前循环次数 (索引最小为0)。 forloop.revcounter 剩余循环次数 (索引最小为1)。 forloop.revcounter0 剩余循环次数 (索引最小为0)。 forloop.first 第一次循环时为 True 。 forloop.last 最后一次循环时为 True 。 forloop.parentloop 用于嵌套循环,表示当前循环外层的循环。 if {% if %} 标签测试一个变量,若变量为真(即其存在、非空,且不是一个为假的布尔值),区块中的内容就会被输出: {% if athlete_list %} Number of athletes: {{ athlete_list|length }} {% else %} No athletes. {% endif %} 若 athlete_list 非空,变量 {{ athlete_list|length }} 就会显示运动员的数量。 正如你所见, if 标签有可选的 {% else %} 从句,若条件不成立则显示该从句。 if 语句可使用 and 、 or 和 not 来测试变量或者对给定的变量取反: {% if athlete_list and coach_list %} Both athletes and coaches are available. {% endif %} {% if not athlete_list %} There are no athletes. {% endif %} {% if athlete_list or coach_list %} There are some athletes or some coaches. {% endif %} {% if not athlete_list or coach_list %} There are no athletes or there are some coaches (OK, so writing English translations of Boolean logic sounds stupid; it's not our fault). {% endif %} {% if athlete_list and not coach_list %} There are some athletes and absolutely no coaches. {% endif %} 不允许 and 和 or 同时出现在一个 if 语句中,因为这样会有逻辑上的问题。例如这样是有语病的: {% if athlete_list and coach_list or cheerleader_list %} 如果你需要同时使用 and 和 or 来实现较高级的逻辑,可以用嵌套的 if 标签来实现。例如: {% if athlete_list %} {% if coach_list or cheerleader_list %} We have athletes, and either coaches or cheerleaders! {% endif %} {% endif %} 重复使用同一逻辑符是可以的。例如这样是正确的: {% if athlete_list or coach_list or parent_list or teacher_list %} ifchanged 检查循环中一个值从最近一次重复其是否改变。 ifchanged 语句块用于循环中,其作用有两个: 它会把要渲染的内容与前一次作比较,发生变化时才显示它。例如,下面要显示一个日期列表,只有月份改变时才会显示它:

Archive for {{ year }}

{% for date in days %} {% ifchanged %}

{{ date|date:"F" }}

{% endifchanged %} {{ date|date:"j" }} {% endfor %} 如果给的是一个变量,就会检查它是否发生改变。 {% for date in days %} {% ifchanged date.date %} {{ date.date }} {% endifchanged %} {% ifchanged date.hour date.date %} {{ date.hour }} {% endifchanged %} {% endfor %} 前面那个例子中日期每次发生变化时就会显示出来,但只有小时和日期都发生变化时才会显示小时。 ifequal 如果两个参数相等,就输出该区块的内容。 举个例子: {% ifequal user.id comment.user_id %} ... {% endifequal %} 正如 {% if %} 标签一样, {% else %} 语句是可选的。 参数也可以是硬编码的字符串,所以下面这种写法是正确的: {% ifequal user.username "adrian" %} ... {% endifequal %} 可以用来比较的参数只限于模板变量或者字符串(实际上整数和小数也是可以的——译注),你不能检查诸如 True or False 等Python对象是否相等。如果你需要测试某值的真假,可以用 if 标签。 ifnotequal 和 ifequal 类似,不过它是用来测试两个参数是 不 相等的。 include 加载一个模板,并用当前上下文对它进行渲染,这是在一个模板中包含其他模板的一种方法。 模板名可以是一个变量或者是一个硬编码(引号引起来的)的字符串,引号可以是单引号或者双引号。 这个例子包含了 "foo/bar.html" 模板的内容: {% include "foo/bar.html" %} 这个例子包含了名字由变量 template_name 指定的模板的内容: {% include template_name %} load 读入一个自定义的模板库。第十章里有关于自定义模板的相关信息资料 now 根据给定的格式字符串显示当前日期。 这个标签来源于PHP中的 date() 函数( http://php.net/date ),并使用与其相同的格式语法,但是Django对其做了扩展。 表F-2显示了可用的格式字符串。 表F-2. 可用的日期格式字符串 格式字符 串 描述 示例输出 a 'a.m.' 或者 'p.m.' 。(这与PHP中的输出略有不同, 因为为了匹配美联社风格,它包含了句点。 'a.m.' A 'AM' 或者 'PM' 。 'AM' b 月份,文字式的,三个字母,小写。 'jan' d 一月的第几天,两位数字,带前导零。 '01' 到 '31' D 一周的第几天,文字式的,三个字母。 'Fri' f 时间,12小时制的小时和分钟数,如果分钟数为零则不显示。 '1' , '1:30' F 月份,文字式的,全名。 'January' g 小时,12小时制,没有前导零。 '1' 到 '12' G 小时,24小时制,没有前导零。 '0' 到 '23' h 小时,12小时制。 '01' 到 '12' H 小时,24小时制。 '00' 到 '23' i 分钟。 '00' 到 '59' j 一月的第几天,不带前导零。 '1' 到 '31' l 一周的第几天,文字式的,全名。 'Friday' L 是否为闰年的布尔值。 True 到 False m 月份,两位数字,带前导零。 '01' 到 '12' M 月份,文字式的,三个字母。 'Jan' n 月份,没有前导零。 '1' 到 '12' N 美联社风格的月份缩写。 'Jan.' , 'Feb.' , 'March' , 'May' O 与格林威治标准时间的时间差(以小时计)。 '+0200' P 时间,12小时制的小时分钟数以及a.m./p.m.,分钟数如果为零 则不显示,用字符串表示特殊时间点,如 'midnight' 和 'noon' 。 '1 a.m.' , '1:30 p.m.' , 'midnight' , 'noon' , '12:30 p.m.' r RFC 822 格式的日期。 'Thu, 21 Dec 2000 16:01:07 +0200' s 秒数,两位数字,带前导零。 '00' 到 '59' S 英语序数后缀,用于表示一个月的第几天,两个字母。 'st' , 'nd' , 'rd' 到 'th' t 指定月份的天数。 28 到 31 T 本机的时区。 'EST' , 'MDT' w 一周的第几天,数字,带前导零。 '0' (Sunday) 到 '6' (Saturday) W ISO-8601 一年中的第几周,一周从星期一开始。 1 , 23 y 年份,两位数字。 '99' Y 年份,四位数字。 '1999' z 一年的第几天。 0 到 365 Z 以秒计的时区偏移量,这个偏移量对于UTC西部时区总是负数, 对于UTC东部时区总是正数。 -43200 到 43200 看这个例子: It is {% now "jS F Y H:i" %} 记住,如果你想用一个字符串的原始值的话,你可以用反斜线进行转义。在这个例子中,f被用反斜线转义了,如果不转义的话f就是显示时间的格式字符串。o不用转义,因为它本来就不是一个格式字母。 It is the {% now "jS o\f F" %} 这样就会显示成“It is the 4th of September”。 regroup 把一列相似的对象根据某一个共有的属性重新分组。 要解释清这个复杂的标签,最好来举个例子。比如, people 是包含 Person 对象的一个列表, 这个对象拥有 first_name 、 last_name 和 gender 属性,你想这样显示这个列表: * Male: * George Bush * Bill Clinton * Female: * Margaret Thatcher * Condoleezza Rice * Unknown: * Pat Smith 下面这段模板代码就可以完成这个看起来很复杂的任务: {% regroup people by gender as grouped %} 如你所见, {% regroup %} 构造了一个列表变量,列表中的每个对象都有 grouper 和 list 属性。 grouper 包含分组所依据的属性, list 包含一系列拥有共同的 grouper 属性的对象。这样 grouper 就会是 Male 、 Female 和 Unknown , list 就是属于这几种性别的人们。 记住,如果被分组的列表不是按照某一列排好序的话,你就不能用 {% regroup %} 在这一列上进行重新分组!就是说如果人的列表不是按照性别排好序的话,在用它之前就要先对它排序,即: {% regroup people|dictsort:"gender" by gender as grouped %} spaceless 去除HTML标签之间的空白符号,包括制表符和换行符。 例如: {% spaceless %}

Foo

{% endspaceless %} 返回结果如下:

Foo

仅仅 标签 之间的空白符被删掉,标签和文本之间的空白符是不会被处理的。在下面这个例子中, Hello 两边的空白符是不会被截掉的: {% spaceless %} Hello {% endspaceless %} ssi 把一个指定的文件的内容输出到页面上。 像include标签一样, {% ssi %} 会包含另外一个文件的内容,这个文件必须以绝对路径指明: {% ssi /home/html/ljworld.com/includes/right_generic.html %} 如果指定了可选的parsed参数的话,包含进来的文件的内容会被当作模板代码,并用当前的上下文来渲染: {% ssi /home/html/ljworld.com/includes/right_generic.html parsed %} 注意,如果你要使用 {% ssi %} 的话,为了安全起见,你必须在Django配置文件中定义ALLOWED_INCLUDE_ROOTS。 大多数情况下 {% include %} 比 {% ssi %} 更好用, {% ssi %} 的存在通常是为了向后兼容。 templatetag 输出组成模板标签的语法字符。 模板系统没有转义的概念,所以要显示一个组成模板标签的字符的话,你必须使用 {% templatetag %} 标签。 参数用来标明要显示的字符(参见表F-3)。 表F-3. templatetag的有效参数 参数 输出 openblock {% closeblock %} openvariable {{ closevariable }} openbrace { closebrace } opencomment {# closecomment #} url 根据所给视图函数和可选参数,返回一个绝对的URL(就是不带域名的URL)。由于没有在模板中对URL进行硬编码,所以这种输出链接的方法没有违反DRY原则。 {% url path.to.some_view arg1,arg2,name1=value1 %} 第一个变量是按package.package.module.function形式给出的指向一个view函数的路径。那些可选的、用逗号分隔的附加参数被用做URL中的位置和关键词变量。所有URLconf需要的参数都应该是存在的。 例如,假设你有一个view,app_name.client,它的URLconf包含一个client ID参数。URLconf对应行可能看起来像这样: ('^client/(\d+)/$', 'app_name.client') 如果这个应用的URLconf像下面一样被包含在项目的URLconf里: ('^clients/', include('project_name.app_name.urls')) 那么,在模板中,你可以像这样创建一个指向那个view的link连接: {% url app_name.client client.id %} 模板标签将输出字符串/clients/client/123/ widthratio,寬度的比率 為了畫出長條圖,這個標籤計算一個給定值相對於最大值的比率,然後將這個比率給定一個常數 一些实例: If this_value is 175 and max_value is 200, the image in the preceding example will be 88 pixels wide (because 175/200 = .875; .875 * 100 = 87.5, which is rounded up to 88). [b]内建过滤器参考[/b] 过滤器参数必须使用双引号,即使是这样多重双引号的情况下 一、形式:小写 {{ name | lower }} 二、串联:先转义文本到HTML,再转换每行到

标签 {{ my_text|escape|linebreaks }} 三、过滤器的参数 显示前30个字 {{ bio | truncatewords:"30" }} 格式化 {{ pub_date | date:"F j, Y" }} 过滤器列表 {{ 123|add:"5" }} 给value加上一个数值 {{ "AB'CD"|addslashes }} 单引号加上转义号,一般用于输出到javascript中 {{ "abcd"|capfirst }} 第一个字母大写 {{ "abcd"|center:"50" }} 输出指定长度的字符串,并把值对中 {{ "123spam456spam789"|cut:"spam" }} 查找删除指定字符串 {{ value|date:"F j, Y" }} 格式化日期 {{ value|default:"(N/A)" }} 值不存在,使用指定值 {{ value|default_if_none:"(N/A)" }} 值是None,使用指定值 {{ 列表变量|dictsort:"数字" }} 排序从小到大 {{ 列表变量|dictsortreversed:"数字" }} 排序从大到小 {% if 92|divisibleby:"2" %} 判断是否整除指定数字 {{ string|escape }} 转换为html实体 {{ 21984124|filesizeformat }} 以1024为基数,计算最大值,保留1位小数,增加可读性 {{ list|first }} 返回列表第一个元素 {{ "ik23hr&jqwh"|fix_ampersands }} &转为& {{ 13.414121241|floatformat }} 保留1位小数,可为负数,几种形式 {{ 13.414121241|floatformat:"2" }} 保留2位小数 {{ 23456 |get_digit:"1" }} 从个位数开始截取指定位置的1个数字 {{ list|join:", " }} 用指定分隔符连接列表 {{ list|length }} 返回列表个数 {% if 列表|length_is:"3" %} 列表个数是否指定数值 {{ "ABCD"|linebreaks }} 用新行用


标记包裹 {{ "ABCD"|linebreaksbr }} 用新行用
标记包裹 {{ 变量|linenumbers }} 为变量中每一行加上行号 {{ "abcd"|ljust:"50" }} 把字符串在指定宽度中对左,其它用空格填充 {{ "ABCD"|lower }} 小写 {% for i in "1abc1"|make_list %}ABCDE,{% endfor %} 把字符串或数字的字符个数作为一个列表 {{ "abcdefghijklmnopqrstuvwxyz"|phone2numeric }} 把字符转为可以对应的数字?? {{ 列表或数字|pluralize }} 单词的复数形式,如列表字符串个数大于1,返回s,否则返回空串 {{ 列表或数字|pluralize:"es" }} 指定es {{ 列表或数字|pluralize:"y,ies" }} 指定ies替换为y {{ object|pprint }} 显示一个对象的值 {{ 列表|random }} 返回列表的随机一项 {{ string|removetags:"br p div" }} 删除字符串中指定html标记 {{ string|rjust:"50" }} 把字符串在指定宽度中对右,其它用空格填充 {{ 列表|slice:":2" }} 切片 {{ string|slugify }} 字符串中留下减号和下划线,其它符号删除,空格用减号替换 {{ 3|stringformat:"02i" }} 字符串格式,使用Python的字符串格式语法 {{ "EABCD"|striptags }} 剥去[X]HTML语法标记 {{ 时间变量|time:"P" }} 日期的时间部分格式 {{ datetime|timesince }} 给定日期到现在过去了多少时间 {{ datetime|timesince:"other_datetime" }} 两日期间过去了多少时间 {{ datetime|timeuntil }} 给定日期到现在过去了多少时间,与上面的区别在于2日期的前后位置。 {{ datetime|timeuntil:"other_datetime" }} 两日期间过去了多少时间 {{ "abdsadf"|title }} 首字母大写 {{ "A B C D E F"|truncatewords:"3" }} 截取指定个数的单词 {{ "111221"|truncatewords_html:"2" }} 截取指定个数的html标记,并补完整

多重嵌套列表展现为html的无序列表 {{ string|upper }} 全部大写 linkage url编码 {{ string|urlize }} 将URLs由纯文本变为可点击的链接。(没有实验成功) {{ string|urlizetrunc:"30" }} 同上,多个截取字符数。(同样没有实验成功) {{ "B C D E F"|wordcount }} 单词数 {{ "a b c d e f g h i j k"|wordwrap:"5" }} 每指定数量的字符就插入回车符 {{ boolean|yesno:"Yes,No,Perhaps" }} 对三种值的返回字符串,对应是 非空,空,None   Generated by Bo-blog 2.1.2 beta 3