3

我的一个模型中有以下代码

class PostImage(models.Model):
    post =  models.ForeignKey(Post, related_name="images")
    # @@@@ figure out a way to have image folders per user...
    image = models.ImageField(upload_to='images')
    image_infowindow = models.ImageField(upload_to='images')
    image_thumb = models.ImageField(upload_to='images')
    image_web = models.ImageField(upload_to='images')
    description = models.CharField(max_length=100)
    order = models.IntegerField(null=True)

    IMAGE_SIZES = {
        'image_infowindow':(70,70),
        'image_thumb':(100,100),
        'image_web':(640,480),
    }

    def delete(self, *args, **kwargs):
        # delete files..
        self.image.delete(save=False)
        self.image_thumb.delete(save=False)
        self.image_web.delete(save=False)
        self.image_infowindow.delete(save=False)
        super(PostImage, self).delete(*args, **kwargs)

我试图在调用 delete() 方法时删除文件PostImage。但是,这些文件不会被删除。

如您所见,我重写了 delete() 方法,并删除了每个ImageField. 然而,由于某种原因,这些文件没有被删除。

4

1 回答 1

8

您可以使用多种方法删除模型实例。

一种方法是调用delete()

PostImage.objects.get(...).delete()

在这种情况下,delete()将调用 ,因此文件将被删除。但是,您也可以使用查询集删除对象:

PostImage.objects.filter(...).delete()

不同的是,使用后一种方法,Django 会使用 SQLDELETE命令批量删除对象,因此delete()不会调用每个对象的方法。因此,您可能正在使用查询集删除对象,因此不会删除文件。

您可以通过使用post_deleteDjango 信号来解决此问题,如下所示:

@receiver(post_delete, sender=PostImage)
def post_delete_user(sender, instance, *args, **kwargs):
    instance.image.delete(save=False)
    instance.image_thumb.delete(save=False)
    instance.image_web.delete(save=False)
    instance.image_infowindow.delete(save=False)

请注意,如果您使用此方法,则不必再覆盖该delete()方法。

更多关于这里这里

于 2012-10-15T03:33:57.627 回答