python - django 模板里如何多個值相加?
問題描述
models.py
class Order(models.Model): price_a = models.PositiveIntegerField(blank=True, null=True) price_b = models.PositiveIntegerField(blank=True, null=True) price_c = models.PositiveIntegerField(blank=True, null=True)
views.py
def order_list(): order_list = Order.objects.all() return render(request, ’orders/order_list.html’, {’order_list’: order_list})
模板:
{% for order in order_list %} price_* 可能是 None 這里想輸出 price_a + price_b + price_b 的總和 下面這個寫法沒有用: {{ price_a|add:price_b|add:price_c }}{% endfor %}
求解,或者有沒有其他的實現方法?
問題解答
回答1:根據你所述的需求,有兩種解決辦法:1,在views.py里面計算好之后再傳到模板里面;2,自定義模板filters來實現,具體實現方式如下:
第一步:在你項目的app目錄下新建templatetags文件夾(該文件夾和你的views.py和models.py同級),并在該文件夾下新建__init__.py和add_value.py文件,目錄結構如下:
|-- views.py|-- models.py|templatetags |-- __init__.py |-- add_value.py
第二步:編輯__init__.py和add_value.py文件。__init__.py文件為空即可,add_value.py文件內容如下:
# coding:utf-8__author__ = ’Dell’from django import templateregister = template.Library()@register.filter(name=’add_value’)def add_value(values): count = 0 # 這里的values就是你使用該標簽時傳入的參數,在這個例子里面values就是render的時候傳給模板的order_list的值 # 所以這里可以根據你實際傳入的值做處理 for v in values:if v[’key’]: count += int(v[’key’]) return count
第三步:在views.py里面:
# 這里假設你order_list的值是[{’key’: 1}, {’key’: 2}, {’key’: 3}]render(request, ’orders/order_list.html’, {’order_list’: [{’key’: 1}, {’key’: 2}, {’key’: 3}]})
第四步:在你的order_list.html模板里面加入{% load add_value %},然后使用<p>{{ order_list|add_value }}</p>
最后應該就可以實現你的需求了,希望可以幫到你哈。
回答2:你不可以直接在view里面處理好再在模板里面引用嗎?
相關文章:
1. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf2. mysql - 數據庫表中,兩個表互為外鍵參考如何解決3. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?4. mysql - 數據庫建字段,默認值空和empty string有什么區別 1105. mysql儲存json錯誤6. sql語句 - 如何在mysql中批量添加用戶?7. mysql - 表名稱前綴到底有啥用?8. php - 公眾號文章底部的小程序二維碼如何統計?9. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?10. mysql - 怎么生成這個sql表?
