我的一个模型中有以下代码
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)
我试图在PostImage
上调用delete()方法时删除文件。但是,文件未被删除。
如您所见,我重写了delete()方法,并删除了每个ImageField
。但是出于某种原因,文件没有被删除。
答案 0 :(得分:7)
您可以使用多种方法删除模型实例。
一种方法是调用delete()
:
PostImage.objects.get(...).delete()
在这种情况下,调用delete()
,因此将删除文件。但是,您也可以使用querysets删除对象:
PostImage.objects.filter(...).delete()
不同之处在于使用后一种方法,Django将使用SQL DELETE
命令批量删除对象,因此不会调用每个对象的delete()
方法。因此,您可能正在使用查询集删除对象,因此不会删除文件。
您可以使用post_delete
Django信号解决此问题,如下所示:
@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()
方法。