我想知道我计算quantity * price_gross
的方法是否正确。还是有更好的方法在Ticket.objects.
查询集中将这些值相乘?
event = Event.objects.get(pk=4)
test = Ticket.objects.filter(event=event).values('quantity', 'price_gross')
result = 0
for x in test:
result += x['quantity']*x['price_gross']
print(result)
更新:
Ticket.objects.filter(
event__organizer__in=self.organizers,
event__status=EventStatus.LIVE,
).values('event__pk', 'pk')
.order_by('event__pk')
.annotate(
total_gross=F('quantity') * F('price_gross'),
)
.aggregate(Sum('total_gross'))
最佳答案
是。确实有一种方法可以做到,那就是使用Query Expressions
test = Ticket.objects.filter(event=event).annotate(total=F('quantity') * F('price_gross'))
关于python - Django:在查询集中乘以,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/56599281/