Django 使用easy_thumbnails压缩上传的图片方法
easy_thumbnails:Apowerful,yeteasytoimplementthumbnailingapplicationforDjango1.4+
安装
pipinstalleasy_thumbanils
在你的项目中配置
setting.pyINSTALLED_APPS中添加‘easy_thumbanils'
如果Django1.7及以上,运行pythonmanage.pymigrateeasy_thumbnails
否则,运行pythonmanage.pysyncdb
在Django中压缩
setting.py
首先,setting中添加
THUMBNAIL_ALIASES={ '':{ 'avatar':{'size':(200,200),'crop':True}, }, }
size控制要压缩后的图片大小
创建模型
eg:
models.py
fromeasy_thumbnails.fieldsimportThumbnailerImageField classGoodsImage(models.Model): Img=ThumbnailerImageField(upload_to='images/',blank=True)
ThumbnailerImageField在数据库中做的事相当于models.ImageField,不同的是他会告诉esay_thumbnails这是一个要被压缩的图片域。(个人推测)
获取缩略图路径
两种,一是在模板中,二在视图中
模板:
views.py
frommodelsimportGoodsImage deftest(request): goods=GoodsMessage.objects.all().first()#查到一个图片 returnrender(request,'templates.html',{'img':goods})#使用模板
templates.html
{%loadthumbnail%}{#装载easy_thumbnail#}{#原图#} {#压缩图#}
视图
views.py
fromeasy_thumbnails.filesimportget_thumbnailer frommodelsimportGoodsImage deftest2(request): goods=GoodsImage.objects.all().first() path=get_thumbnailer(goods.Img) print(path)#注意,这里查到的是url编码的图片地址 returnHttpResponse(path)
第二种方法,直接查找:
goods=GoodsImage.objects.all().first() goods.Img#原图地址 goods.Img['avatar']#缩略图地址 goods.Img['avatar'].url#经url编码后的缩略图地址 #avatar是你在setting.py中的缩略图尺寸名
根据我的观察,只有当第一次使用GoodsImage.object.*()这种查询的时候,才会生成缩略图,并非在保存原图时就生成了。
此外,使用时候发现当图片表一条记录被删除后,thumbanils的数据表记录不会删除,不过在使用中未发现异常
以上这篇Django使用easy_thumbnails压缩上传的图片方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。