Django模板中變量的運算實現
在django中的模板下我們知道變量使用{{xxx}}來呈現,可是當出現兩個變量進行運算怎麼處理那?
#加法: {{value|add:value2}} #返回的結果是value+value2的值,假設你value為40,value2為60 ,則該表達式 #返回結果為100
#減法 {{value|add -value2}} #與加法的性質一樣,隻不過是把第二個參數變成負數進行運算,返回的結果是value-value2 #假如value=4,value2=8,則返回的結果是-4
#乘法 {% widthratio value1 value2 value3%} #上面的代碼表示 value1/value2*value3,widthratio需要三個參數,進行乘法 隻需將第二個參數等於1即可 #例: value1=10 value2=1 value3=2 返回的結果為10/1*2=20
#除法 {% widthratio value1 value2 value3%} #返回的結果是 (value1/value2)*value3 隻需將value3等於1就能進行除法運算 #例: value1=100 value2=20 value3=1 返回的結果為 (100/20)*1=5
數據保留兩位小數
<td>{{ foo.product_amount |floatformat:5 }}</td> register = template.Library()
一些復雜一些的運算
利用 add 這個filter ,可以做更瘋狂的事:
- 計算 A^2: {% widthratio A 1 A %}
- 計算 (A+B)^2: {% widthratio A|add:B 1 A|add:B %}
- 計算 (A+B) * (C+D): {% widthratio A|add:B 1 C|add:D %}
除法並保留小數
首先定義方法在templatehelper.py文件中
@register.filter def div(value, div): ''' 分轉化為元,保留兩位小數 :param value: :param div: :return: ''' return round((value / div), 2)
然後在模板中可以按照如下使用,當然前提是{% load templatehelper %}:
<td>{{ foo.product_amount |div:100 }}</td>
嘗試過一個笨辦法,但是不生效,而且就算生效,也會出現忽略掉小數點後面得值的情況,所以不建議:
<td>{% widthratio foo.product_amount 100 1 as width %}{% blocktrans %}{{ width }}{% endblocktrans %}</td>#}
到此這篇關於Django模板中變量的運算的文章就介紹到這瞭,更多相關Django模板變量運算內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- None Found