Приветствую!
Есть две модели Album и Photo
class Album(models.Model):
name = models.CharField(blank=True, max_length=30)
title = models.CharField(max_length=50, verbose_name='Название альбома')
description = models.TextField(blank=True, verbose_name='Описание альбома')
class Meta:
verbose_name = 'Альбом'
verbose_name_plural = 'альбомы'
ordering = ['name']
def __unicode__(self):
return self.title
class Photo (models.Model):
item = models.ForeignKey(Album, verbose_name='Название альбома')
title = models.CharField(max_length=100, verbose_name='Название фото')
image = ThumbnailImageField(upload_to='photos', verbose_name='Фото')
caption = models.TextField(blank=True, verbose_name='Описание фото')
class Meta:
verbose_name = 'Фотография'
verbose_name_plural = 'фотографии'
ordering = ['title']
def __unicode__(self):
return self.title
Подскажите как правильно организовать одиночное удаление фотографии с диска при удалении одиночного экземпляра Photo и множественное, когда удаляется весь альбом?
На данный момент, если я удаляю какой-то экземпляр Photo или Album, то просто удаляется запись из БД и не более. Физически фотографии остаются на диске.
ThumbnailImageField - это экземпляр класса ImageFieldFile, который позволяет уменьшить загружаемое изображение и сделать из него превьюху. Вроде бы метод delete() и прописан, но почему-то файл физически не удаляется, а лишь стирается запись в БД.
class ThumbnailImageFieldFile(ImageFieldFile):
def _get_thumb_path(self):
return _add_thumb(self.path)
thumb_path = property(_get_thumb_path)
def _get_thumb_url(self):
return _add_thumb(self.url)
thumb_url = property(_get_thumb_url)
@staticmethod
def _scale_dimensions(width, height, longest_side=800):
if width > height:
koeficent = float(width)/float(longest_side)
width = longest_side
height = int(height/koeficent)
return width, height
elif width < height:
koeficent = float(height)/float(longest_side)
height = longest_side
width = int(width/koeficent)
return width, height
else:
return longest_side, longest_side
def save(self, name, content, save=True):
from datetime import datetime
dt = str(datetime.now()).replace('-','_') .replace(':','') .replace(' ','_')
img_name = 'img_'+dt.split('.')[0]+'.jpg'
super(ThumbnailImageFieldFile, self).save(img_name, content, save)
img = Image.open(self.path)
(width, height) = img.size
if width>800 or height>800:
(width, height) = self._scale_dimensions(width, height)
newImg = img.resize((width, height), Image.ANTIALIAS)
newImg.save(self.path, 'JPEG')
img.thumbnail(
(self.field.thumb_width, self.field.thumb_height),
Image.ANTIALIAS
)
img.save(self.thumb_path, 'JPEG')
def delete(self, save=True):
if os.path.exists(self.thumb_path):
os.remove(self.thumb_path)
super(ThumbnailImageFieldFile, self).delete(save)
class ThumbnailImageField(ImageField):
"""
Behaves like a regular ImageField, but stores an extra (JPEG) thumbnail
image, providing FIELD.thumb_url and FIELD.thumb_path.
Accepts two additional, optional arguments: thumb_width and thumb_height,
both defaulting to 200 (pixels). Resizing will preserve aspect ratio while
staying inside the requested dimensions; see PIL's Image.thumbnail()
method documentation for details.
"""
attr_class = ThumbnailImageFieldFile
def __init__(self, thumb_width=200, thumb_height=200, *args, **kwargs):
#self.img_name = img_name
self.thumb_width = thumb_width
self.thumb_height = thumb_height
super(ThumbnailImageField, self).__init__(*args, **kwargs)
Заранее благодарен!