在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模板变量运算内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:- python Django模板的使用方法(图文)
- Django模板变量如何传递给外部js调用的方法小结
- python+django加载静态网页模板解析
- 基于Django模板中的数字自增(详解)
- 在Django框架中自定义模板过滤器的方法
- django小技巧之html模板中调用对象属性或对象的方法
- django admin 自定义替换change页面模板的方法
- 浅谈Django自定义模板标签template_tags的用处