私はこの質問が複数回掲載されていることを知っていますが、私はまだこの問題に対する明確な答えを見つけることができませんでした。だから、私は行く:DjangoモデルカスタムSave ManyToManyField問題
class Invoice(models.Model):
program = models.ForeignKey(Program)
customer = models.ForeignKey(Customer, related_name='invoices')
participants = models.ManyToManyField(Participant, related_name='participants_set')
subtotal = models.DecimalField(max_digits=10, decimal_places=2, default='0.00', blank=True, null=False)
pst = models.DecimalField("PST", max_digits=10, decimal_places=2, default='0.00', blank=True, null=False)
gst = models.DecimalField("GST", max_digits=10, decimal_places=2, default='0.00', blank=True, null=False)
total = models.DecimalField(max_digits=10, decimal_places=2, default='0.00', blank=True, null=False)
def save(self, **kwargs):
super(Invoice, self).save(**kwargs)
items = self.participants.count()
subtotal = Decimal(self.program.fee) * items
pst = self.program.is_pst and Decimal(PST)*subtotal or Decimal('0.00')
gst = self.program.is_gst and Decimal(GST)*subtotal or Decimal('0.00')
total = (subtotal + pst) + gst
self.subtotal = subtotal
self.pst = pst
self.gst = gst
self.total = total
super(Invoice, self).save(**kwargs)
すべてがうまくいきますが、self.participants.count()は動作しません。どんなアイデアであっても問題ではありません。どんな助けでも大歓迎です。
どのバージョン:ソリューションはadmin.ModelAdminからのManyToManyFieldを削除するだけでしたか? self.participants.count()の呼び出しがうまくいくはずです。 – Harold
countメソッドは例外を発生させますか、それとも間違った値を返しますか? –