当前位置 博文首页 > Django模板中变量的运算实现

    Django模板中变量的运算实现

    作者:老_男孩 时间:2021-07-03 18:39

    在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>#}
    
    jsjbwy
    下一篇:没有了