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学习RabbitMQ消息队列
Nov 30 Python
Python基于二分查找实现求整数平方根的方法
May 12 Python
python中模块的__all__属性详解
Oct 26 Python
解析Python中的eval()、exec()及其相关函数
Dec 20 Python
python使用itchat库实现微信机器人(好友聊天、群聊天)
Jan 04 Python
对Python实现累加函数的方法详解
Jan 23 Python
Python数据处理篇之Sympy系列(五)---解方程
Oct 12 Python
使用Python串口实时显示数据并绘图的例子
Dec 26 Python
tensorflow指定GPU与动态分配GPU memory设置
Feb 03 Python
Django model重写save方法及update踩坑详解
Jul 27 Python
宝塔更新Python及Flask项目的部署
Apr 11 Python
python和Appium的移动端多设备自动化测试框架
Apr 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 switch语句多个值匹配同一代码块的实现
2014/03/03 PHP
PHP+AjaxForm异步带进度条上传文件实例代码
2017/08/14 PHP
PHP的PDO预定义常量讲解
2019/01/24 PHP
JavaScript 对话框和状态栏使用说明
2009/10/25 Javascript
jQuery拖动图片删除示例
2013/05/10 Javascript
自写的jQuery异步加载数据添加事件
2014/05/15 Javascript
jquery validate.js表单验证入门实例(附源码)
2015/11/10 Javascript
JQuery解析XML数据的几个简单实例
2016/05/18 Javascript
jQuery与JS加载事件用法分析
2016/09/04 Javascript
详解基于angular路由的requireJs按需加载js
2017/01/20 Javascript
实例详解JavaScript中setTimeout函数的执行顺序
2017/07/12 Javascript
用js实现每隔一秒刷新时间的实例(含年月日时分秒)
2017/10/25 Javascript
JavaScript程序设计高级算法之动态规划实例分析
2017/11/24 Javascript
微信小程序使用wxParse解析html的实现示例
2018/08/30 Javascript
Angular7.2.7路由使用初体验
2019/03/01 Javascript
ES6中异步对象Promise用法详解
2019/07/31 Javascript
[40:03]DOTA2上海特级锦标赛主赛事日 - 1 败者组第一轮#1EHOME VS Archon
2016/03/02 DOTA
[01:48:04]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Elephant BO3 第一场 2月7日
2021/03/11 DOTA
python中sets模块的用法实例
2014/09/30 Python
放弃 Python 转向 Go语言有人给出了 9 大理由
2017/10/20 Python
python 弹窗提示警告框MessageBox的实例
2019/06/18 Python
在windows下使用python进行串口通讯的方法
2019/07/02 Python
Python爬虫实现模拟点击动态页面
2020/03/05 Python
解决python DataFrame 打印结果不换行问题
2020/04/09 Python
python爬虫基础之urllib的使用
2020/12/31 Python
医学类导师推荐信范文
2013/11/19 职场文书
共产党员公开承诺书
2014/03/25 职场文书
基层党员群众路线教育实践活动个人对照检查材料思想汇报
2014/10/05 职场文书
教师三严三实学习心得体会
2014/10/11 职场文书
公务员个人考察材料
2014/12/23 职场文书
2015年世界卫生日活动总结
2015/02/09 职场文书
村党组织公开承诺书
2015/04/30 职场文书
采购部年度工作总结
2015/08/13 职场文书
Python基础之赋值,浅拷贝,深拷贝的区别
2021/04/30 Python
mysql 如何获取两个集合的交集/差集/并集
2021/06/08 MySQL
Python 阶乘详解
2021/10/05 Python