您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
在最近做项目时,发现服务器上的图片比较大,数据传输时会消耗很多流量,体验非常不好。为了缓解这一现象,决定使用gzip压缩数据流,但是发现gzip对于json数据的压缩效果很好,但对于图片的压缩效果很差。无奈,只能写一段代码,将服务器上的图片挨个压缩一下。
我的服务器上的程序,是用django写的,数据库为sqlite,图片文件存储在media目录下。
先看models.py,只有一个ImageField类型的变量picture,也就是一会压缩图片需要用到的变量。
class CrossPicture(models.Model): picture = models.ImageField(upload_to='cross_picture', blank=True, null=True)
Python有一个PIL库,可以处理图像,压缩部分的代码就是用PIL写的
def compressImage(request): picture_list = models.CrossPicture.objects.all() for cp in picture_list: image = Image.open(cp.picture) # 通过cp.picture 获得图像 width = image.width height = image.height rate = 1.0 # 压缩率 # 根据图像大小设置压缩率 if width >= 2000 or height >= 2000: rate = 0.3 elif width >= 1000 or height >= 1000: rate = 0.5 elif width >= 500 or height >= 500: rate = 0.9 width = int(width * rate) # 新的宽 height = int(height * rate) # 新的高 image.thumbnail((width, height), Image.ANTIALIAS) # 生成缩略图 image.save('media/' + str(cp.picture), 'JPEG') # 保存到原路径 cp.save() return HttpResponse('compress ok')
以上这篇django 使用 PIL 压缩图片的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持亿速云。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。