diff options
author | Hasan Ramezani <hasan.r67@gmail.com> | 2019-10-25 14:57:37 +0200 |
---|---|---|
committer | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2019-10-29 14:29:39 +0100 |
commit | f57e174fa61e4c31213f6d0033fb9d647b463626 (patch) | |
tree | 6219dd6cc8624c8352758f0a9063a81e0ea0ba8b /docs/topics | |
parent | bf7b3e2750e3392d112b34e076ee1a77c8adbe77 (diff) | |
download | django-f57e174fa61e4c31213f6d0033fb9d647b463626.tar.gz |
Fixed #13750 -- Clarified need to reopen models.ImageField.image file to access raw image data.
Diffstat (limited to 'docs/topics')
-rw-r--r-- | docs/topics/files.txt | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/docs/topics/files.txt b/docs/topics/files.txt index b5b9101523..dff933e321 100644 --- a/docs/topics/files.txt +++ b/docs/topics/files.txt @@ -73,6 +73,27 @@ location (:setting:`MEDIA_ROOT` if you are using the default >>> car.photo.path == new_path True +.. note:: + + Whilst :class:`~django.db.models.ImageField` non-image data attributes, + such as ``height``, ``width``, and ``size`` are available on the instance, + the underlying image data cannot be used without reopening the image. For + example:: + + >>> from PIL import Image + >>> car = Car.objects.get(name='57 Chevy') + >>> car.photo.width + 191 + >>> car.photo.height + 287 + >>> image = Image.open(car.photo) + # Raises ValueError: seek of closed file. + >>> car.photo.open() + <ImageFieldFile: cars/chevy.jpg> + >>> image = Image.open(car.photo) + >>> image + <PIL.JpegImagePlugin.JpegImageFile image mode=RGB size=1600x1200 at 0x7F99A94E9048> + The ``File`` object =================== |