我很难找到将计算数据打印到模板的方法。我会尽力描述我的情况。我有一个名为股息的模型:
class Dividend(models.Model):
date = models.DateField('pay date')
amount = models.FloatField( validators=[MinValueValidator(0.001), MaxValueValidator(1000000000000000.0)])
price = models.FloatField('price per share',
validators=[MinValueValidator(0.001), MaxValueValidator(1000000000000000.0)])
股息数据表如下所示:
Date Dividend Price
Sept. 26, 2013 $0.8 $24.75
June 26, 2013 $0.7 $24.74
March 26, 2013 $0.6 $23.59
Dec. 13, 2012 $0.4 $19.18
Sept. 26, 2012 $0.1 $20.66
我想增加每笔股息是如何筹集的百分比(如果是的话)。所以是这样的:
Date Dividend Price
Sept. 26, 2013 $0.8 (+12,5%) $24.75
June 26, 2013 $0.7 (+14,28%) $24.74
March 26, 2013 $0.6 (+50%) $23.59
Dec. 13, 2012 $0.4 (+300%) $19.18
Sept. 26, 2012 $0.1 $20.66
我该怎么做呢?我在列表中有数据,因为我添加了一些我不想插入到数据库中的红利。所以我有一个股息对象列表。基本上我想计算视图中的百分比变化并将其作为另一个参数添加到每个股息中。
for dividend in dividend_list:
dividend.change = ...calculation...
而不是简单地将它添加到我的模板中
{% for dividend in stock.dividend_set.all|order_by:"date" %}
<tr>
<td>{{ dividend.date }}</td>
<td>${{ dividend.amount }} ({{ dividend.change }}%)</td>
<td>${{ dividend.price }}</td>
</tr>
{% endfor %}
但是我做不到,因为Dividend中没有模型字段变化。我存储在新的 QueryDict 中,其中键是股息.id 和值百分比变化。但我不能在模板中做 query_dict[dividend.id] 。那么最好的方法是什么?很抱歉问了这么一个微不足道的问题,但我不知道该寻找什么。很抱歉标题不令人满意,如果我在您的回复后想出更具描述性的内容,我会更改它。