这篇文章给大家分享的是Django模板中两个变量运算的实现,文中示例代码介绍的非常详细,对大家学习和理解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 ,可以做更疯狂的事:
除法并保留小数
首先定义方法在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的应用,可以继续浏览群英网络其他相关的文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理