[英]how can I get the sum of all expense based on current logged user in django?
我用來匯總分配給用戶的所有費用值。 我無法在我的網頁中顯示它。 我怎樣才能做到這一點? models.py 代碼如下:
class expense(models.Model):
Expensecat=(('food','Food'),
('transportation','Transportation'),
('education','Education'),
('health','Health'),
('clothes','Clothes'),
('beauty','Beauty'),
('hosuehold','Household'),
)
ExpenseAmount=models.FloatField(max_length=100)
Category=models.CharField(max_length=200,choices= Expensecat)
Description=models.TextField(max_length=200)
Date=models.DateTimeField(default=timezone.now)
user=models.ForeignKey(User,on_delete=models.CASCADE)
視圖.py
def home(request):
try:
expense_total = expense.objects.filter(user=request.user).aggregate(expenses=Sum('ExpenseAmount'))
except TypeError:
print('No data')
data = {
'Expense':expense_total['expenses'],
}
return render(request, 'budget/home.html', data )
HTML 代碼:
<div class="col-lg-3 col-md-6 d-flex stat my-3">
<div class="mx-auto">
<h6 class="text-muted">Expense</h6>
<h3 class="font-weight-bold">{{ Expense.expenses }}</h3>
<h6 class="text-success"></h6>
</div>
您將其分配給Expense
變量,因此您使用Expense
渲染它,而不是Expense.expenses
,您已經“解包”了字典中的值:
{{ Expense }}
注意:當你用錢進行計算時,最好使用
DecimalField
[Django-doc] ,而不是FloatField
[Django-doc] 。 執行計算時,浮點數會產生舍入誤差。 你也可以使用django-money
[GitHub]來指定一個MoneyField
。 這也指定了一種貨幣,並且可以將貨幣轉換為不同的貨幣。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.