欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django 模板中常用的過(guò)濾器實(shí)現(xiàn)

 更新時(shí)間:2021年05月25日 08:33:50   作者:Silent丿丶黑羽  
在模版中,有時(shí)候需要對(duì)一些數(shù)據(jù)進(jìn)行處理以后才能使用。一般在Python中我們是通過(guò)函數(shù)的形式來(lái)完成的。而在模版中,則是通過(guò)過(guò)濾器來(lái)實(shí)現(xiàn)的,本文就來(lái)介紹一下如何實(shí)現(xiàn)

模版常用過(guò)濾器

在模版中,有時(shí)候需要對(duì)一些數(shù)據(jù)進(jìn)行處理以后才能使用。一般在Python中我們是通過(guò)函數(shù)的形式來(lái)完成的。而在模版中,則是通過(guò)過(guò)濾器來(lái)實(shí)現(xiàn)的。過(guò)濾器使用的是|來(lái)使用。

add

將傳進(jìn)來(lái)的參數(shù)添加到原來(lái)的值上面。這個(gè)過(guò)濾器會(huì)嘗試將值和參數(shù)轉(zhuǎn)換成整形然后進(jìn)行相加。如果轉(zhuǎn)換成整形過(guò)程中失敗了,那么會(huì)將值和參數(shù)進(jìn)行拼接。如果是字符串,那么會(huì)拼接成字符串,如果是列表,那么會(huì)拼接成一個(gè)列表。示例代碼如下:

{{ value|add:"2" }}

如果value是等于4,那么結(jié)果將是6。如果value是等于一個(gè)普通的字符串,比如abc,那么結(jié)果將是abc2。add過(guò)濾器的源代碼如下:

def add(value, arg):
    """Add the arg to the value."""
    try:
        return int(value) + int(arg)
    except (ValueError, TypeError):
        try:
            return value + arg
        except Exception:
            return ''

cut

移除值中所有指定的字符串。類似于python中的replace(args,"")。示例代碼如下:

{{ value|cut:" " }}

以上示例將會(huì)移除value中所有的空格字符。cut過(guò)濾器的源代碼如下:

def cut(value, arg):
    """Remove all values of arg from the given string."""
    safe = isinstance(value, SafeData)
    value = value.replace(arg, '')
    if safe and arg != ';':
        return mark_safe(value)
    return value

date

將一個(gè)日期按照指定的格式,格式化成字符串。示例代碼如下:

# 數(shù)據(jù)
context = {
    "birthday": datetime.now()
}

# 模版
{{ birthday|date:"Y/m/d" }}

那么將會(huì)輸出2018/02/01。其中Y代表的是四位數(shù)字的年份,m代表的是兩位數(shù)字的月份,d代表的是兩位數(shù)字的日。
還有更多時(shí)間格式化的方式。見(jiàn)下表。

格式字符 描述 示例
Y 四位數(shù)字的年份 2020
m 兩位數(shù)字的月份 01-12
n 月份,1-9前面沒(méi)有0前綴 1-12
d 兩位數(shù)字的天 01-31
j 天,但是1-9前面沒(méi)有0前綴 1-31
g 小時(shí),12小時(shí)格式的,1-9前面沒(méi)有0前綴 1-12
h 小時(shí),12小時(shí)格式的,1-9前面有0前綴 01-12
G 小時(shí),24小時(shí)格式的,1-9前面沒(méi)有0前綴 1-23
H 小時(shí),24小時(shí)格式的,1-9前面有0前綴 01-23
i 分鐘,1-9前面有0前綴 00-59
s 秒,1-9前面有0前綴 00-59

default

如果值被評(píng)估為False。比如[],"",None,{}等這些在if判斷中為False的值,都會(huì)使用default過(guò)濾器提供的默認(rèn)值。示例代碼如下:

{{ value|default:"nothing" }}

如果value是等于一個(gè)空的字符串。比如"",那么以上代碼將會(huì)輸出nothing。 

default_if_none

如果值是None,那么將會(huì)使用default_if_none提供的默認(rèn)值。這個(gè)和default有區(qū)別,default是所有被評(píng)估為False的都會(huì)使用默認(rèn)值。而default_if_none則只有這個(gè)值是等于None的時(shí)候才會(huì)使用默認(rèn)值。示例代碼如下:

{{ value|default_if_none:"nothing" }}

如果value是等于""也即空字符串,那么以上會(huì)輸出空字符串。如果value是一個(gè)None值,以上代碼才會(huì)輸出nothing。

first

返回列表/元組/字符串中的第一個(gè)元素。示例代碼如下:

{{ value|first }}

如果value是等于['a','b','c'],那么輸出將會(huì)是a。

last

返回列表/元組/字符串中的最后一個(gè)元素。示例代碼如下:

{{ value|last }}

如果value是等于['a','b','c'],那么輸出將會(huì)是c。 

floatformat

使用四舍五入的方式格式化一個(gè)浮點(diǎn)類型。如果這個(gè)過(guò)濾器沒(méi)有傳遞任何參數(shù)。那么只會(huì)在小數(shù)點(diǎn)后保留一個(gè)小數(shù),如果小數(shù)后面全是0,那么只會(huì)保留整數(shù)。當(dāng)然也可以傳遞一個(gè)參數(shù),標(biāo)識(shí)具體要保留幾個(gè)小數(shù)。

如果沒(méi)有傳遞參數(shù):

value 模版代碼 輸出
34.23234 {{ value|floatformat }} 34.2
34.000 {{ value|floatformat }} 34
34.260 {{ value|floatformat }} 34.3

如果傳遞參數(shù):

value 模版代碼 輸出
34.23234 {{ value|floatformat:3 }} 34.232
34.000 {{ value|floatformat:3 }} 34.000
34.26000 {{ value|floatformat:3 }} 34.260

join

類似與Python中的join,將列表/元組/字符串用指定的字符進(jìn)行拼接。示例代碼如下:

{{ value|join:"/" }}

如果value是等于['a','b','c'],那么以上代碼將輸出a/b/c。 

length

獲取一個(gè)列表/元組/字符串/字典的長(zhǎng)度。示例代碼如下:

{{ value|length }}

如果value是等于['a','b','c'],那么以上代碼將輸出3。如果value為None,那么以上將返回0。

lower

將值中所有的字符全部轉(zhuǎn)換成小寫。示例代碼如下:

{{ value|lower }}

如果value是等于Hello World。那么以上代碼將輸出hello world。

upper

類似于lower,只不過(guò)是將指定的字符串全部轉(zhuǎn)換成大寫。

random

在被給的列表/字符串/元組中隨機(jī)的選擇一個(gè)值。示例代碼如下:

{{ value|random }}

如果value是等于['a','b','c'],那么以上代碼會(huì)在列表中隨機(jī)選擇一個(gè)。

safe

標(biāo)記一個(gè)字符串是安全的。也即會(huì)關(guān)掉這個(gè)字符串的自動(dòng)轉(zhuǎn)義。示例代碼如下:

{{value|safe}}

如果value是一個(gè)不包含任何特殊字符的字符串,比如<a>這種,那么以上代碼就會(huì)把字符串正常的輸入。如果value是一串html代碼,那么以上代碼將會(huì)把這個(gè)html代碼渲染到瀏覽器中。 

slice

類似于Python中的切片操作。示例代碼如下:

{{ some_list|slice:"2:" }}

以上代碼將會(huì)給some_list從2開(kāi)始做切片操作。

stringtags

刪除字符串中所有的html標(biāo)簽。示例代碼如下:

{{ value|striptags }}

如果value是<strong>hello world</strong>,那么以上代碼將會(huì)輸出hello world。 

truncatechars

如果給定的字符串長(zhǎng)度超過(guò)了過(guò)濾器指定的長(zhǎng)度。那么就會(huì)進(jìn)行切割,并且會(huì)拼接三個(gè)點(diǎn)來(lái)作為省略號(hào)。示例代碼如下:

{{ value|truncatechars:5 }}

如果value是等于北京歡迎您~,那么輸出的結(jié)果是北京...??赡苣銜?huì)想,為什么不會(huì)北京歡迎您...呢。因?yàn)槿齻€(gè)點(diǎn)也占了三個(gè)字符,所以北京+三個(gè)點(diǎn)的字符長(zhǎng)度就是5。

truncatechars_html

類似于truncatechars,只不過(guò)是不會(huì)切割html標(biāo)簽。示例代碼如下:

{{ value|truncatechars:5 }}

如果value是等于<p>北京歡迎您~</p>,那么輸出將是<p>北京...</p>。

到此這篇關(guān)于Django 模板中常用的過(guò)濾器實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Django 模板過(guò)濾器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論