Python基于opencv的图像压缩算法实例分析


Posted in Python onMay 03, 2018

本文实例讲述了Python基于opencv的图像压缩算法。分享给大家供大家参考,具体如下:

插值方法:

CV_INTER_NN - 最近邻插值,
CV_INTER_LINEAR - 双线性插值 (缺省使用)
CV_INTER_AREA - 使用象素关系重采样。当图像缩小时候,该方法可以避免波纹出现。当图像放大时,类似于 CV_INTER_NN 方法..
CV_INTER_CUBIC - 立方插值.

函数 cvResize 将图像 src 改变尺寸得到与 dst 同样大小。若设定 ROI,函数将按常规支持 ROI.

程序1:图像压缩(第一版)

# coding=utf-8
import time
time1 = time.time()
import cv2
image=cv2.imread("c:/1.jpg")
res = cv2.resize(image, (1280,960), interpolation=cv2.INTER_AREA)
# cv2.imshow('image', image)
# cv2.imshow('resize', res)
# cv2.waitKey(0)
# cv2.destroyAllWindows()
cv2.imwrite("C:/5.jpg",res)
time2=time.time()
print u'总共耗时:' + str(time2 - time1) + 's'

4.19M—377k 压缩了11倍

程序2:图像压缩(第二版)

#-*-coding:utf-8-*-
#############设置编码################
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
###################导入计算机视觉库opencv和图像处理库PIL####################
from PIL import Image
from PIL import ImageEnhance
from PIL import ImageFilter
import cv2
import time
time1 = time.time()
####################读入图像###############################
image=cv2.imread("c:/pic//0.jpg")
####################双三次插值#############################
res = cv2.resize(image, (1280,960), interpolation=cv2.INTER_AREA)
####################写入图像########################
cv2.imwrite("C:/pic/101.jpg",res)
###########################图像对比度增强##################
imgE = Image.open("c:/pic/101.jpg")
imgEH = ImageEnhance.Contrast(imgE)
img1=imgEH.enhance(2.8)
########################图像转换为灰度图###############
gray = img1.convert("L")
gray.save("C:/pic/3.jpg")
##########################图像增强###########################
# 创建滤波器,使用不同的卷积核
gary2=gray.filter(ImageFilter.DETAIL)
gary2.save("C:/pic/2.jpg")
#############################图像点运算#################
gary3=gary2.point(lambda i:i*0.9)
gary3.save("C:/pic/4.jpg")
# img1.show("new_picture")
time2=time.time()
print u'总共耗时:' + str(time2 - time1) + 's'

4.17M?>290kb

程序3:函数版本

#-*-coding:utf-8-*-
#############设置编码################
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
############导入计算机视觉库opencv和图像处理库PIL####################
from PIL import Image
from PIL import ImageEnhance
from PIL import ImageFilter
import cv2
import time
time1 = time.time()
########################自定义图像压缩函数############################
def img_zip(path,filename1,filename2):
  image = cv2.imread(path+filename1)
  res = cv2.resize(image, (1280, 960), interpolation=cv2.INTER_AREA)
  cv2.imwrite(path+filename2, res)
  imgE = Image.open(path+filename2)
  imgEH = ImageEnhance.Contrast(imgE)
  img1 = imgEH.enhance(2.8)
  gray1 = img1.convert("L")
  gary2 = gray1.filter(ImageFilter.DETAIL)
  gary3 = gary2.point(lambda i: i * 0.9)
  gary3.save(path+filename2)
################################主函数##################################
if __name__ == '__main__':
  path=u"c:/pic/"
  filename1="0.jpg"
  filename2="1.jpg"
  img_zip(path,filename1,filename2)
  time2 = time.time()
  print u'总共耗时:' + str(time2 - time1) + 's'

更多关于Python相关内容可查看本站专题:《Python数学运算技巧总结》、《Python图片操作技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python实现方便使用的级联进度信息实例
May 05 Python
Python如何判断数独是否合法
Sep 08 Python
python更改已存在excel文件的方法
May 03 Python
TensorFlow 滑动平均的示例代码
Jun 19 Python
Python中修改字符串的四种方法
Nov 02 Python
PyCharm-错误-找不到指定文件python.exe的解决方法
Jul 01 Python
Python函数式编程指南:对生成器全面讲解
Nov 19 Python
Python unittest工作原理和使用过程解析
Feb 24 Python
python实现最短路径的实例方法
Jul 19 Python
python 基于opencv去除图片阴影
Jan 26 Python
pytorch finetuning 自己的图片进行训练操作
Jun 05 Python
python识别围棋定位棋盘位置
Jul 26 Python
python实现数据导出到excel的示例--普通格式
May 03 #Python
python操作xlsx文件的包openpyxl实例
May 03 #Python
对Python字符串中的换行符和制表符介绍
May 03 #Python
pandas数据处理基础之筛选指定行或者指定列的数据
May 03 #Python
Python爬虫实现全国失信被执行人名单查询功能示例
May 03 #Python
Python 解决中文写入Excel时抛异常的问题
May 03 #Python
python 将数据保存为excel的xls格式(实例讲解)
May 03 #Python
You might like
在PHP中利用XML技术构造远程服务(下)
2006/10/09 PHP
php利用云片网实现短信验证码功能的示例代码
2017/11/18 PHP
js计算页面刷新的次数
2009/07/20 Javascript
jquery.Jwin.js 基于jquery的弹出层插件代码
2012/05/23 Javascript
用jquery仿做发微博功能示例
2014/04/18 Javascript
JavaScript设计模式之策略模式实例
2014/10/10 Javascript
javascript判断数组内是否重复的方法
2015/04/21 Javascript
JavaScript中数据结构与算法(三):链表
2015/06/19 Javascript
JS获取文件大小方法小结
2015/12/08 Javascript
Javascript自执行匿名函数(function() { })()的原理浅析
2016/05/15 Javascript
微信小程序链接传参并跳转新页面
2016/11/29 Javascript
js实现漫天星星效果
2017/01/19 Javascript
浅谈JS验证表单文本域输入空格的问题
2017/02/14 Javascript
详解js类型判断
2018/05/22 Javascript
vue项目使用高德地图的定位及关键字搜索功能的实例代码(踩坑经验)
2020/03/07 Javascript
[59:08]DOTA2上海特级锦标赛C组小组赛#2 LGD VS Newbee第一局
2016/02/27 DOTA
python中使用正则表达式的后向搜索肯定模式(推荐)
2017/11/11 Python
Django的分页器实例(paginator)
2017/12/01 Python
python距离测量的方法
2018/03/06 Python
python将文本中的空格替换为换行的方法
2018/03/19 Python
如何用Python 加密文件
2020/09/10 Python
css 省略号 css3让多余的字符串消失并附加省略号的实现代码
2013/02/07 HTML / CSS
实习生自荐信范文
2013/11/13 职场文书
心理学专业毕业生推荐信范文
2013/11/21 职场文书
高中生家长寄语大全
2014/04/03 职场文书
岗位说明书范文
2014/05/07 职场文书
献爱心捐款倡议书
2014/05/14 职场文书
奥运会口号
2014/06/13 职场文书
传播学专业毕业生自荐书
2014/07/01 职场文书
2014年发展党员工作总结
2014/11/12 职场文书
食品安全责任书范本
2015/05/09 职场文书
家长会主持词开场白
2015/05/29 职场文书
大学生奶茶店创业计划书
2019/06/25 职场文书
SQL实现LeetCode(197.上升温度)
2021/08/07 MySQL
德生2P3收音机开箱评测
2022/04/30 无线电
mysql sock文件存储了什么信息
2022/07/15 MySQL