django-sorl создает IOError при использовании синтаксиса шаблона - PullRequest
2 голосов
/ 08 марта 2011

Я настроил django-sorl, и я действительно думаю, что пропускаю что-то простое. Я продолжаю получать следующую ошибку (TEMPLATE_DEBUG = True и THUMBNAIL_DEBUG = True)

Метод запроса: GET URL запроса: http://localhost:8000/events/edit/1

Django Версия: 1.2.4 Тип исключения: Значение исключения TemplateSyntaxError:

Поступил IOError при рендеринге: (2, «Нет такого файла или каталога»)

Местоположение исключения: /usr/lib/python2.6/site-packages/django/core/files/storage.py в _open, строка 137

Исполняемый файл Python: / usr / bin / python Python Версия: 2.6.4

У меня запущена установка сервера redis ... Моя конфигурация sorl:

settings.py -snip -:

TEMPLATE_DEBUG = DEBUG
THUMBNAIL_DEBUG = DEBUG
THUMBNAIL_KVSTORE = 'sorl.thumbnail.kvstores.redis_kvstore.KVStore'
INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.messages',
    'sorl.thumbnail',
)

models.py -snip -:

from sorl.thumbnail import ImageField
...
    path = ImageField(
       _('Image'),
        upload_to='event/%Y/%m/%d/%H',
    )
...

template.html -snip -:

{% load thumbnail %}
...
{% thumbnail image "200x100" as im %}
    <img src="{{ im.url }}" alt="{{ im.name }}"/>
{% endthumbnail %}
...

Я полагаю, что я близко, потому что файлы создаются по требованию в папке кеша

sh> find static/cache/ -type f 
static/cache/db/ac/dbac605942d9651eb25f16cf05f5e672.jpg
static/cache/82/bc/82bcdd2ab079187c6b6110cb0e0c1505.jpg
static/cache/07/77/077784411739d4f8b1758255783388ec.jpg

Когда я открываю эти файлы; это изображения, которые я запрашиваю по требованию. Кажется, бомба пытается открыть изображение, чтобы отобразить его. Еще одна вещь, которую стоит отметить, это то, что если я просто отображу изображение, используя следующий синтаксис, оно будет работать нормально (без sorl):

рабочий template.html (без sorl - следовательно ... без миниатюр) -snip -:

<img src="{{ MEDIA_URL}}{{ image.path }}" alt="{{ image.name }}"/>

Ключ существо; что мне нужно добавить префикс {{MEDIA_URL}} для присутствия изображения (я не уверен, является ли это причиной ошибки, которую я получаю с sorl, или просто с красной сельдью.

Теперь несколько заключительных отрывков исходной ошибки (они взяты из создаваемой страницы TemplateSyntaxError - последние 5).

# /var/project/src/lib/sorl/thumbnail/base.py in get_thumbnail

  36. thumbnail = ImageFile(name, default.storage)
  37. cached = default.kvstore.get(thumbnail)
  38. if cached:
  39. return cached
  40. if not thumbnail.exists():
  41. # We have to check exists() because the Storage backend does not
  42. # overwrite in some implementations.
  43. source_image = default.engine.get_image(source) ...
  44. # We might as well set the size since we have the image in memory
  45. size = default.engine.get_image_size(source_image)
  46. source.set_size(size)
  47. self._create_thumbnail(source_image, geometry_string, options,
  48. thumbnail)
  49. # If the thumbnail exists we don't create it, the other option is

▼ Local vars Variable Value cached None file_ <EventImage: TestImage> geometry_string u'200x100' key 'format' name 'cache/24/69/246986cc89951f1d37235b8f0dec0a54.jpg' options {'colorspace': 'RGB', 'crop': False, 'format': 'JPEG', 'quality': 95, 'upscale': True} self    <sorl.thumbnail.base.ThumbnailBackend object at 0x7f5b885f2c10> source <sorl.thumbnail.images.ImageFile object at 0x7f5b885c81d0> thumbnail <sorl.thumbnail.images.ImageFile object at 0x7f5b8867f510> value 'JPEG'
# /var/project/src/lib/sorl/thumbnail/engines/pil_engine.py in get_image

   5. from PIL import Image, ImageDraw
   6. except ImportError:
   7. import Image, ImageDraw
   8.
   9.
  10. class Engine(EngineBase):
  11. def get_image(self, source):

  12. buf = StringIO(source.read()) ...

  13. return Image.open(buf)
  14.
  15. def get_image_size(self, image):
  16. return image.size
  17.
  18. def dummy_image(self, width, height):

▼ Local vars Variable Value self <sorl.thumbnail.engines.pil_engine.Engine object at 0x7f5b886cf450> source <sorl.thumbnail.images.ImageFile object at 0x7f5b885c81d0>
# /home/caronc/Development/cityattention/src/lib/sorl/thumbnail/images.py in read

 114. return self._size
 115.
 116. @property
 117. def url(self):
 118. return self.storage.url(self.name)
 119.
 120. def read(self):
 121. return self.storage.open(self.name).read() ...
 122.
 123. def write(self, content):
 124. if not isinstance(content, File):
 125. content = ContentFile(content)
 126. self._size = None
 127. return self.storage.save(self.name, content)

▼ Local vars Variable Value self <sorl.thumbnail.images.ImageFile object at 0x7f5b885c81d0>
# /usr/lib/python2.6/site-packages/django/core/files/storage.py in open

  25. # These shouldn't be overridden by subclasses unless absolutely necessary.
  26.
  27. def open(self, name, mode='rb', mixin=None):
  28. """
  29. Retrieves the specified file from storage, using the optional mixin
  30. class to customize what features are available on the File returned.
  31. """
  32. file = self._open(name, mode) ...
  33. if mixin:
  34. # Add the mixin as a parent class of the File returned from storage.
  35. file.__class__ = type(mixin.__name__, (mixin, file.__class__), {})
  36. return file
  37.
  38. def save(self, name, content):

▼ Local vars Variable Value mixin None mode 'rb' name u'TestImage' self      <django.core.files.storage.FileSystemStorage object at 0x7f5b8867f3d0>
# /usr/lib/python2.6/site-packages/django/core/files/storage.py in _open

 130. location = settings.MEDIA_ROOT
 131. if base_url is None:
 132. base_url = settings.MEDIA_URL
 133. self.location = os.path.abspath(location)
 134. self.base_url = base_url
 135.
 136. def _open(self, name, mode='rb'):
 137. return File(open(self.path(name), mode)) ...
 138.
 139. def _save(self, name, content):
 140. full_path = self.path(name)
 141.
 142. directory = os.path.dirname(full_path)
 143. if not os.path.exists(directory):

▼ Local vars Variable Value mode 'rb' name u'TestImage' self <django.core.files.storage.FileSystemStorage object at 0x7f5b8867f3d0>

Я безуспешно гуглил по этой ошибке; Я надеюсь, что моя проблема только быстрая, поскольку все работает, кроме отображения шаблона.

Ответы [ 2 ]

1 голос
/ 14 марта 2011

В вашей модели у вас есть атрибут path.Это path определяется как ImageField, и в конечном итоге это то место, откуда будет доступно изображение для создания окончательного эскиза.sorl.thumbnail не может угадать, что вы имеете в виду, передавая экземпляр модели, вам нужно передать изображение source , которое в вашем случае выглядит как image.path.Ваш комментарий о возврате self.image.path в методе __unicode__ кажется неправильным и, вероятно, должен быть self.path, если вы все еще говорите о той же модели, которая определяет path.

1 голос
/ 09 марта 2011

Документация была немного слабой в этой области, но после импорта отладчика Python я смог выяснить, где была проблема.

Существует 2 возможных решения этой проблемы.вопрос.Первым, что исправило все для меня, было изменение моего шаблона следующим образом:

{% load thumbnail %}
...
{% thumbnail image.path "200x100" as im %}
    <img src="{{ im.url }}" alt="{{ im.name }}"/>
{% endthumbnail %}
...

Я предполагаю, что проблема все еще может быть в моем конце;тем более что этот инструмент был пуленепробиваемым уже некоторое время.Тем не менее, тем, кто испытывает ту же проблему, нужно будет добавить аргумент .path , чтобы уберечь себя от пережитого мной горя.

Альтернативный (не очень хороший) вариант -чтобы добавить это в файл models.py, а затем снова обратиться к изображению напрямую (как я сделал в моем первоначальном вопросе).

def __unicode__(self):
    return self.image.path

Это, конечно, неприятное решение, если объект, содержащий событие, которое вы пытаетесьДисплей не несет ответственности за отображение изображений.Следовательно ... второй вариант может быть идеальным только в «некоторых» ситуациях.Я бы остановился на первом обходном пути.

Этот обходной путь применим к патчу 10.12.1.

Кроме того, для обоснования моего первоначального вопроса.Я заявил, что статические изображения были созданы;как оказалось, это было неправильно.Хотя эти изображения были «правильными» миниатюрами изображений, я не смог заставить их работать на своей странице.Они автоматически генерировались из инструмента DJango-Admin.Вероятно, когда я пытался загрузить разные изображения (неправильно решая проблему).:)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...