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中基于生成器的状态机
Apr 13 Python
Python sys.argv用法实例
May 28 Python
用ReactJS和Python的Flask框架编写留言板的代码示例
Dec 19 Python
python UNIX_TIMESTAMP时间处理方法分析
Apr 18 Python
TensorFlow深度学习之卷积神经网络CNN
Mar 09 Python
详解基于python-django框架的支付宝支付案例
Sep 23 Python
Python检查图片是否损坏及图片类型是否正确过程详解
Sep 30 Python
如何利用pycharm进行代码更新比较
Nov 04 Python
python3定位并识别图片验证码实现自动登录功能
Jan 29 Python
python基于tkinter制作无损音乐下载工具
Mar 29 Python
拒绝盗图!教你怎么用python给图片加水印
Jun 04 Python
OpenCV-Python实现轮廓的特征值
Jun 09 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预定义接口――Iterator用法示例
2020/06/05 PHP
Mootools 1.2教程 设置和获取样式表属性
2009/09/15 Javascript
用AJAX返回HTML片段中的JavaScript脚本
2010/01/04 Javascript
关于javascript function对象那些迷惑分析
2011/10/24 Javascript
jquery实现侧边弹出的垂直导航
2014/12/09 Javascript
JavaScript中eval()函数用法详解
2015/12/14 Javascript
很棒的js选项卡切换效果
2016/07/15 Javascript
angularJS 如何读写缓冲的方法(推荐)
2016/08/06 Javascript
浅谈JQ中mouseover和mouseenter的区别
2016/09/13 Javascript
chrome下判断点击input上标签还是其余标签的实现方法
2016/09/18 Javascript
基于Vue如何封装分页组件
2016/12/16 Javascript
微信小程序 九宫格实例代码
2017/01/21 Javascript
jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法
2017/03/08 Javascript
MUI 上拉刷新/下拉加载功能实例代码
2017/04/13 Javascript
Vue结合Video.js播放m3u8视频流的方法示例
2018/05/04 Javascript
vue实现压缩图片预览并上传功能(promise封装)
2019/01/10 Javascript
深入理解Node内建模块和对象
2019/03/12 Javascript
微信小程序自定义头部导航栏和导航栏背景图片 navigationStyle问题
2019/07/26 Javascript
解决layui弹框失效的问题
2019/09/09 Javascript
简单介绍Ruby中的CGI编程
2015/04/10 Python
Django自定义插件实现网站登录验证码功能
2017/04/19 Python
python 反向输出字符串的方法
2018/07/16 Python
Python 实现自动导入缺失的库
2019/10/29 Python
浅析python,PyCharm,Anaconda三者之间的关系
2019/11/27 Python
Python数据可视化图实现过程详解
2020/06/12 Python
米兰网婚纱礼服法国网上商店:Milanoo法国
2016/08/20 全球购物
国际经济与贸易专业大学生职业规划书
2014/03/01 职场文书
报纸媒体创意广告词
2014/03/17 职场文书
安全宣传标语口号
2014/06/06 职场文书
行政管理专业求职信
2014/07/06 职场文书
优秀少先队辅导员事迹材料
2014/12/24 职场文书
运动会闭幕词
2015/01/28 职场文书
光荣之路观后感
2015/06/12 职场文书
社区服务活动感想
2015/08/11 职场文书
成功的商业计划书这样写才最靠谱
2019/07/12 职场文书
为了顺利买到演唱会的票用Python制作了自动抢票的脚本
2021/10/16 Python