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!