python读取图片任意范围区域


Posted in Python onJanuary 23, 2019

使用python进行图片处理,现在需要读出图片的任意一块区域,并将其转化为一维数组,方便后续卷积操作的使用。
下面使用两种方法进行处理:

convert 函数

from PIL import Image
import numpy as np
import matplotlib.pyplot as plt

def ImageToMatrix(filename):
 im = Image.open(filename)  # 读取图片
 im.show()      # 显示图片
 width,height = im.size
 print("width is :" + str(width))
 print("height is :" + str(height))
 im = im.convert("L")    # pic --> mat 转换,可以选择不同的模式,下面有函数源码具体说明
 data = im.getdata()
 data = np.matrix(data,dtype='float')/255.0
 new_data = np.reshape(data * 255.0,(height,width))
 new_im = Image.fromarray(new_data)
 # 显示从矩阵数据得到的图片
 new_im.show()
 return new_data

def MatrixToImage(data):
 data = data*255
 new_im = Image.fromarray(data.astype(np.uint8))
 return new_im

'''
 convert(self, mode=None, matrix=None, dither=None, palette=0, colors=256)
  |  Returns a converted copy of this image. For the "P" mode, this
  |  method translates pixels through the palette. If mode is
  |  omitted, a mode is chosen so that all information in the image
  |  and the palette can be represented without a palette.
  |  
  |  The current version supports all possible conversions between
  |  "L", "RGB" and "CMYK." The **matrix** argument only supports "L"
  |  and "RGB".
  |  
  |  When translating a color image to black and white (mode "L"),
  |  the library uses the ITU-R 601-2 luma transform::
  |  
  |   L = R * 299/1000 + G * 587/1000 + B * 114/1000
  |  
  |  The default method of converting a greyscale ("L") or "RGB"
  |  image into a bilevel (mode "1") image uses Floyd-Steinberg
  |  dither to approximate the original image luminosity levels. If
  |  dither is NONE, all non-zero values are set to 255 (white). To
  |  use other thresholds, use the :py:meth:`~PIL.Image.Image.point`
  |  method.
  |  
  |  :param mode: The requested mode. See: :ref:`concept-modes`.
  |  :param matrix: An optional conversion matrix. If given, this
  |   should be 4- or 12-tuple containing floating point values.
  |  :param dither: Dithering method, used when converting from
  |   mode "RGB" to "P" or from "RGB" or "L" to "1".
  |   Available methods are NONE or FLOYDSTEINBERG (default).
  |  :param palette: Palette to use when converting from mode "RGB"
  |   to "P". Available palettes are WEB or ADAPTIVE.
  |  :param colors: Number of colors to use for the ADAPTIVE palette.
  |   Defaults to 256.
  |  :rtype: :py:class:`~PIL.Image.Image`
  |  :returns: An :py:class:`~PIL.Image.Image` object.

'''

原图:

python读取图片任意范围区域

filepath = "./imgs/"

imgdata = ImageToMatrix("./imgs/0001.jpg")
print(type(imgdata))
print(imgdata.shape)

plt.imshow(imgdata) # 显示图片
plt.axis('off')  # 不显示坐标轴
plt.show()

运行结果:

python读取图片任意范围区域

mpimg 函数

import matplotlib.pyplot as plt  # plt 用于显示图片
import matplotlib.image as mpimg  # mpimg 用于读取图片
import numpy as np

def readPic(picname, filename):
 img = mpimg.imread(picname)
 # 此时 img 就已经是一个 np.array 了,可以对它进行任意处理
 weight,height,n = img.shape  #(512, 512, 3)
 print("the original pic: \n" + str(img))

 plt.imshow(img)     # 显示图片
 plt.axis('off')     # 不显示坐标轴
 plt.show()

 # 取reshape后的矩阵的第一维度数据,即所需要的数据列表
  img_reshape = img.reshape(1,weight*height*n)[0]
  print("the 1-d image data :\n "+str(img_reshape))

 # 截取(300,300)区域的一小块(12*12*3),将该区域的图像数据转换为一维数组
 img_cov = np.random.randint(1,2,(12,12,3))  # 这里使用np.ones()初始化数组,会出现数组元素为float类型,使用np.random.randint确保其为int型
 for j in range(12):
  for i in range(12):
   img_cov[i][j] = img[300+i][300+j]

 img_reshape = img_cov.reshape(1,12*12*3)[0]
 print((img_cov))
 print(img_reshape)

 # 打印该12*12*3区域的图像
 plt.imshow(img_cov) 
 plt.axis('off') 
 plt.show()

 # 写文件
 # open:以append方式打开文件,如果没找到对应的文件,则创建该名称的文件
 with open(filename, 'a') as f:
  f.write(str(img_reshape))
 return img_reshape

if __name__ == '__main__':
 picname = './imgs/0001.jpg'
 readPic(picname, "data.py")

读出的数据(12*12*3),每个像素点以R、G、B的顺序排列,以及该区域显示为图片的效果:

python读取图片任意范围区域

参考:python 读取并显示图片的两种方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python进行数据科学工作的简单入门教程
Apr 01 Python
python基于phantomjs实现导入图片
May 13 Python
python+matplotlib绘制旋转椭圆实例代码
Jan 12 Python
运用TensorFlow进行简单实现线性回归、梯度下降示例
Mar 05 Python
matplotlib实现热成像图colorbar和极坐标图的方法
Dec 13 Python
Django项目中实现使用qq第三方登录功能
Aug 13 Python
python进程间通信Queue工作过程详解
Nov 01 Python
python实现修改固定模式的字符串内容操作示例
Dec 30 Python
TensorFlow Saver:保存和读取模型参数.ckpt实例
Feb 10 Python
python 图像判断,清晰度(明暗),彩色与黑白实例
Jun 04 Python
Python实现手势识别
Oct 21 Python
基于Python实现粒子滤波效果
Dec 01 Python
Python基于plotly模块实现的画图操作示例
Jan 23 #Python
python实现剪切功能
Jan 23 #Python
对python实现合并两个排序链表的方法详解
Jan 23 #Python
Python基于Logistic回归建模计算某银行在降低贷款拖欠率的数据示例
Jan 23 #Python
python实现石头剪刀布程序
Jan 20 #Python
python random从集合中随机选择元素的方法
Jan 23 #Python
python3+selenium实现qq邮箱登陆并发送邮件功能
Jan 23 #Python
You might like
magento后台无法登录解决办法的两种方法
2016/12/09 PHP
php递归函数怎么用才有效
2018/02/24 PHP
浅谈关于JavaScript的语言特性分析
2013/04/11 Javascript
Jquery为a标签的href赋值实现代码
2013/05/03 Javascript
JS实现的N多简单无缝滚动代码(包含图文效果)
2015/11/06 Javascript
jQuery实现页面顶部显示的进度条效果完整实例
2015/12/09 Javascript
Angular2 (RC4) 路由与导航详解
2016/09/21 Javascript
小程序实现多选框功能
2018/10/30 Javascript
vue router 组件的高级应用实例代码
2019/04/08 Javascript
Vue-Cli项目优化操作的实现
2019/10/27 Javascript
解决vue admin element noCache设置无效的问题
2019/11/12 Javascript
js this 绑定机制深入详解
2020/04/30 Javascript
Ant Design moment对象和字符串之间的相互转化教程
2020/10/27 Javascript
tornado框架blog模块分析与使用
2013/11/21 Python
Python3中使用urllib的方法详解(header,代理,超时,认证,异常处理)
2016/09/21 Python
Python实现扩展内置类型的方法分析
2017/10/16 Python
python DataFrame获取行数、列数、索引及第几行第几列的值方法
2018/04/08 Python
python3中的md5加密实例
2018/05/29 Python
pyshp创建shp点文件的方法
2018/12/31 Python
python简单实现AES加密和解密
2019/03/28 Python
Django实现微信小程序的登录验证功能并维护登录态
2019/07/04 Python
PyTorch和Keras计算模型参数的例子
2020/01/02 Python
利用Tensorboard绘制网络识别准确率和loss曲线实例
2020/02/15 Python
完美解决jupyter由于无法import新包的问题
2020/05/26 Python
2019年.net常见面试问题
2012/02/12 面试题
幼儿园开学家长寄语
2014/01/19 职场文书
消防安全管理制度
2014/02/01 职场文书
电子银行营销方案
2014/02/22 职场文书
班组长岗位职责
2014/03/03 职场文书
社区居务公开实施方案
2014/03/27 职场文书
我的中国梦演讲稿300字
2014/08/19 职场文书
十佳少先队员演讲稿
2014/09/12 职场文书
2015年政风行风工作总结
2015/04/21 职场文书
三八妇女节致辞
2015/07/31 职场文书
2016年大学校运会广播稿件
2015/12/21 职场文书
2016年学校党支部公开承诺书
2016/03/25 职场文书