3

これは私を困惑させています...モデルを保存しても、本のオブジェクトは変更されていません。しかし、請求書を開いて再度保存すると、変更が加えられます。私は何が間違っているのですか?

class Invoice(models.Model):
    ...
    books = models.ManyToManyField(Book,blank=True,null=True)
    ...

    def save(self, *args, **kwargs):
        super(Invoice, self).save(*args, **kwargs)
        for book in self.books.all():
            book.quantity -= 1
            if book.quantity == 0:
                book.sold = True;
            book.save()

編集: post_saveシグナルを使用してみましたが、同じように機能します。最初の保存では変更はありません。2回目の保存では変更が保存されます。

更新:このコードで解決されるようです:

class InvoiceAdmin(admin.ModelAdmin):
    ...

    def save_model(self, request, obj, form, change):
        obj.save()
        for bk in form.cleaned_data['books']:
            book = Book.objects.get(pk=bk.id)
            book.quantity -= 1
            if book.quantity == 0:
                book.sold = True;
            book.save()
4

2 に答える 2

5

これは、私がこの、実に不可解な動作を回避した方法です。シグナル レシーバーを models.signals.m2m_changed イベントに接続します。この get は、m2m フィールドが変更されるたびにトリガーされます。インライン コメントで理由が説明されています。

class Gig(models.Model):
    def slugify(self):
        # Add venue name, date and artists to slug
        self.slug = slugify(self.venue.name) + "-"
        self.slug += self.date.strftime("%d-%m-%Y") + "-"
        self.slug += "-".join([slugify(artist.name) for artist in self.artists.all()]) 
        self.save()


@receiver(models.signals.m2m_changed, sender=Gig.artist.through)
def gig_artists_changed(sender, instance, **kwargs):
    # This callback function get's called twice. 
    # 1 first change appears to be adding an empty list
    # 2nd change is adding the actual artists
    if instance.artist.all() and not instance.slug:                                                                                                                                                               
        instance.slugify()
于 2012-08-17T19:25:02.843 に答える