Sumproduct usando agregação do Django

Pergunta, questãoÉ possível usarRecursos de agregação do Django calcular um produto de soma?fundo

Estou modelando uma fatura, que pode conter vários itens. O relacionamento muitos para muitos entre os modelos Fatura e Item é tratado pela tabela intermediária InvoiceItem.

O valor total da fatura—amount_invoiced—É calculado somando o produto deunit_price equantity para cada item em uma determinada fatura. Abaixo está o código que estou usando atualmente para fazer isso, mas queria saber se há uma maneira melhor de lidar com isso usandoRecursos de agregação do Django.

Código atual
class Item(models.Model):
    item_num = models.SlugField(unique=True)
    description = models.CharField(blank=True, max_length=100)


class InvoiceItem(models.Model):
    item = models.ForeignKey(Item)
    invoice = models.ForeignKey('Invoice')
    unit_price = models.DecimalField(max_digits=10, decimal_places=2)
    quantity = models.DecimalField(max_digits=10, decimal_places=4)


class Invoice(models.Model):
    invoice_num = models.SlugField(max_length=25)
    invoice_items = models.ManyToManyField(Item,through='InvoiceItem')

    def _get_amount_invoiced(self):
        invoice_items = self.invoiceitem_set.all()
        amount_invoiced = 0
        for invoice_item in invoice_items:
            amount_invoiced += (invoice_item.unit_price *
                invoice_item.quantity)
        return amount_invoiced

    amount_invoiced = property(_get_amount_invoiced)        

questionAnswers(1)

yourAnswerToTheQuestion