python自动裁剪图像代码分享


Posted in Python onNovember 25, 2017

本代码可以帮你自动剪切掉图片的边缘空白区域,如果你的图片有大片空白区域(只要是同一颜色形成一定的面积就认为是空白区域),下面的python代码可以帮你自动切除,如果是透明图像,会自动剪切大片的透明部分。

本代码需要PIL模块

pil相关介绍

PIL:Python Imaging Library,已经是Python平台事实上的图像处理标准库了。PIL功能非常强大,但API却非常简单易用。

由于PIL仅支持到Python 2.7,加上年久失修,于是一群志愿者在PIL的基础上创建了兼容的版本,名字叫Pillow,支持最新Python 3.x,又加入了许多新特性,因此,我们可以直接安装使用Pillow。

import Image, ImageChops
 
def autoCrop(image,backgroundColor=None):
  '''Intelligent automatic image cropping.
    This functions removes the usless "white" space around an image.
    
    If the image has an alpha (tranparency) channel, it will be used
    to choose what to crop.
    
    Otherwise, this function will try to find the most popular color
    on the edges of the image and consider this color "whitespace".
    (You can override this color with the backgroundColor parameter) 
 
    Input:
      image (a PIL Image object): The image to crop.
      backgroundColor (3 integers tuple): eg. (0,0,255)
         The color to consider "background to crop".
         If the image is transparent, this parameters will be ignored.
         If the image is not transparent and this parameter is not
         provided, it will be automatically calculated.
 
    Output:
      a PIL Image object : The cropped image.
  '''
   
  def mostPopularEdgeColor(image):
    ''' Compute who's the most popular color on the edges of an image.
      (left,right,top,bottom)
       
      Input:
        image: a PIL Image object
       
      Ouput:
        The most popular color (A tuple of integers (R,G,B))
    '''
    im = image
    if im.mode != 'RGB':
      im = image.convert("RGB")
     
    # Get pixels from the edges of the image:
    width,height = im.size
    left  = im.crop((0,1,1,height-1))
    right = im.crop((width-1,1,width,height-1))
    top  = im.crop((0,0,width,1))
    bottom = im.crop((0,height-1,width,height))
    pixels = left.tostring() + right.tostring() + top.tostring() + bottom.tostring()
 
    # Compute who's the most popular RGB triplet
    counts = {}
    for i in range(0,len(pixels),3):
      RGB = pixels[i]+pixels[i+1]+pixels[i+2]
      if RGB in counts:
        counts[RGB] += 1
      else:
        counts[RGB] = 1  
     
    # Get the colour which is the most popular:    
    mostPopularColor = sorted([(count,rgba) for (rgba,count) in counts.items()],reverse=True)[0][1]
    return ord(mostPopularColor[0]),ord(mostPopularColor[1]),ord(mostPopularColor[2])
   
  bbox = None
   
  # If the image has an alpha (tranparency) layer, we use it to crop the image.
  # Otherwise, we look at the pixels around the image (top, left, bottom and right)
  # and use the most used color as the color to crop.
   
  # --- For transparent images -----------------------------------------------
  if 'A' in image.getbands(): # If the image has a transparency layer, use it.
    # This works for all modes which have transparency layer
    bbox = image.split()[list(image.getbands()).index('A')].getbbox()
  # --- For non-transparent images -------------------------------------------
  elif image.mode=='RGB':
    if not backgroundColor:
      backgroundColor = mostPopularEdgeColor(image)
    # Crop a non-transparent image.
    # .getbbox() always crops the black color.
    # So we need to substract the "background" color from our image.
    bg = Image.new("RGB", image.size, backgroundColor)
    diff = ImageChops.difference(image, bg) # Substract background color from image
    bbox = diff.getbbox() # Try to find the real bounding box of the image.
  else:
    raise NotImplementedError, "Sorry, this function is not implemented yet for images in mode '%s'." % image.mode
     
  if bbox:
    image = image.crop(bbox)
     
  return image
 
 
 
#范例:裁剪透明图片:
im = Image.open('myTransparentImage.png')
cropped = autoCrop(im)
cropped.show()
 
#范例:裁剪非透明图片
im = Image.open('myImage.png')
cropped = autoCrop(im)
cropped.show()

 总结

以上就是本文关于python自动裁剪图像代码分享的全部内容,希望对大家有所帮助。如有不足之处,欢迎留言指出。感兴趣的朋友可以继续参阅本站:

Python 相关文章推荐
Python访问MySQL封装的常用类实例
Nov 11 Python
Python2.7编程中SQLite3基本操作方法示例
Aug 09 Python
python使用socket创建tcp服务器和客户端
Apr 12 Python
Python 通过requests实现腾讯新闻抓取爬虫的方法
Feb 22 Python
PyQt5 加载图片和文本文件的实例
Jun 14 Python
Python 等分切分数据及规则命名的实例代码
Aug 16 Python
python SocketServer源码深入解读
Sep 17 Python
python脚本调用iftop 统计业务应用流量的思路详解
Oct 11 Python
Pytorch在NLP中的简单应用详解
Jan 08 Python
Python如何爬取51cto数据并存入MySQL
Aug 25 Python
Python用dilb提取照片上人脸的示例
Oct 26 Python
Python OpenCV超详细讲解调整大小与图像操作的实现
Apr 02 Python
分享一个简单的python读写文件脚本
Nov 25 #Python
python之virtualenv的简单使用方法(必看篇)
Nov 25 #Python
python多进程实现进程间通信实例
Nov 24 #Python
Python实现列表删除重复元素的三种常用方法分析
Nov 24 #Python
Python二叉树的定义及常用遍历算法分析
Nov 24 #Python
详解python上传文件和字符到PHP服务器
Nov 24 #Python
Python实现矩阵转置的方法分析
Nov 24 #Python
You might like
Zend Framework实现留言本分页功能(附demo源码下载)
2016/03/22 PHP
php技巧小结【推荐】
2017/01/19 PHP
javascript 不间断的图片滚动并可点击
2010/01/15 Javascript
跟我学Nodejs(二)--- Node.js事件模块
2014/05/21 NodeJs
jQuery中[attribute^=value]选择器用法实例
2014/12/31 Javascript
jQuery Ajax调用WCF服务详细教程
2015/03/31 Javascript
js如何打印object对象
2015/10/16 Javascript
jQuery四种选择器使用及示例
2016/06/05 Javascript
Javascript6中字符串的四个新用法分享
2016/09/11 Javascript
浅谈Node.js:Buffer模块
2016/12/05 Javascript
JavaScript变量作用域_动力节点Java学院整理
2017/06/27 Javascript
JS动态添加元素及绑定事件造成程序重复执行解决
2017/12/07 Javascript
Angular实现下拉框模糊查询功能示例
2018/01/03 Javascript
Angular4学习教程之DOM属性绑定详解
2018/01/04 Javascript
详解React之父子组件传递和其它一些要点
2018/06/25 Javascript
解决VUE中document.body.scrollTop为0的问题
2018/09/15 Javascript
深入剖析JavaScript instanceof 运算符
2019/06/14 Javascript
深入浅析vue中cross-env的使用
2019/09/12 Javascript
vue cli3 配置proxy代理无效的解决
2019/10/30 Javascript
vue中 v-for循环的用法详解
2020/02/19 Javascript
Python2.x中str与unicode相关问题的解决方法
2015/03/30 Python
python通过文件头判断文件类型
2015/10/30 Python
详解python上传文件和字符到PHP服务器
2017/11/24 Python
Python实现基本数据结构中队列的操作方法示例
2017/12/04 Python
python pandas中对Series数据进行轴向连接的实例
2018/06/08 Python
详解python校验SQL脚本命名规则
2019/03/22 Python
Pytorch之view及view_as使用详解
2019/12/31 Python
Python坐标轴操作及设置代码实例
2020/06/04 Python
python开根号实例讲解
2020/08/30 Python
详解Python利用configparser对配置文件进行读写操作
2020/11/03 Python
详解css3 object-fit属性
2018/07/27 HTML / CSS
前端实现弹幕效果的方法总结(包含css3和canvas的实现方式)
2018/07/12 HTML / CSS
项目专员岗位职责
2013/12/04 职场文书
学习党章思想汇报
2014/01/07 职场文书
煤矿机修工岗位职责
2014/02/07 职场文书
大专学生求职信
2014/07/04 职场文书