easy_thumbnails:A powerful, yet easy to implement thumbnailing application for Django 1.4+
安装
pip install easy_thumbanils
在你的项目中配置
setting.py INSTALLED_APPS中添加 ‘easy_thumbanils’
如果Django1.7及以上,运行python manage.py migrate easy_thumbnails
否则,运行python manage.py syncdb
在Django中压缩
setting.py
首先,setting中添加
THUMBNAIL_ALIASES = {
'': {
'avatar': {'size': (200, 200), 'crop': True},
},
}
size控制要压缩后的图片大小
创建模型
eg:
models.py
from easy_thumbnails.fields import ThumbnailerImageField
class GoodsImage(models.Model):
Img = ThumbnailerImageField(upload_to='images/',blank=True)
ThumbnailerImageField
在数据库中做的事相当于models.ImageField
,不同的是他会告诉esay_thumbnails这是一个要被压缩的图片域。(个人推测)
获取缩略图路径
两种,一是在模板中,二在视图中
模板:
views.py
from models import GoodsImage
def test(request):
goods = GoodsMessage.objects.all().first() # 查到一个图片
return render(request,'templates.html',{'img':goods}) # 使用模板
templates.html
{% load thumbnail %} {# 装载easy_thumbnail #}
<img src="/media/{{ img.Img }}"> {# 原图 #}
<img src="/media/{{ img.Img.avatar.url }}"> {# 压缩图 #}
视图
views.py
from easy_thumbnails.files import get_thumbnailer
from models import GoodsImage
def test2(request):
goods = GoodsImage.objects.all().first()
path = get_thumbnailer(goods.Img)
print(path) # 注意,这里查到的是url编码的图片地址
return HttpResponse(path)
第二种方法,直接查找:
goods = GoodsImage.objects.all().first()
goods.Img # 原图地址
goods.Img['avatar'] # 缩略图地址
goods.Img['avatar'].url # 经url编码后的缩略图地址
# avatar是你在setting.py中的缩略图尺寸名
根据我的观察,只有当第一次使用 GoodsImage.object.*()这种查询的时候,才会生成缩略图,并非在保存原图时就生成了。
此外,使用时候发现当图片表一条记录被删除后,thumbanils的数据表记录不会删除,不过在使用中未发现异常