网络编程
位置:首页>> 网络编程>> Python编程>> python读取图片任意范围区域

python读取图片任意范围区域

作者:sinat_34022298  发布时间:2023-07-16 06:26:21 

标签:python,读取图片

使用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 读取并显示图片的两种方法

来源:https://blog.csdn.net/sinat_34022298/article/details/79533934

0
投稿

猜你喜欢

  • 分页是每一个程序需要去理解的东西,学习过的几门语言中我发现分页原理都是一样的,下面为php初学者分析一下php分页实现与最后面补充了一个超级
  • 前言写过 CLI 常驻进程的老司机肯定遇到过这么一个问题:在需要更新程序的时候,我要怎样才能安全关闭老进程?你可能会想到 NGIN
  • 首先,自学Python是能够找到相关工作的。Python语言在近几年的上升趋势非常明显,语言生态也越来越健全,在Web开发、大数据开发、人工
  • 上次用Javascript+ASP实现了无刷新的新闻列表,最后还有一个小问题没有解决:下边的分页数列"首页、上10页、下10页、尾
  • 处理多个数据和多文件时,使用for循环的速度非常慢,此时需要用多线程来加速运行进度,常用的模块为multiprocess和joblib,下面
  • be前言:期末临近,考Python的同学可以练练问题描述:给定一段长度为N的整数序列A,请从中选出一段连续的子序列(可以为0)使得这段的总和
  • 代码如下:Dim strName, iLoop For Each strName 
  • 如下所示:class Login(QMainWindow):  """登录窗口""
  • 在大多数语音识别任务中,我们都缺少文本和音频特征的alignment,Connectionist Temporal Classificati
  • 预备知识点compile 函数 compile 函数用于编译正则表达式,生成一个正则表达式( Pattern )对象,供 match() 和
  • 我一直不很明白在中国国内流行的设计风格,象在国外的很多地方都有鲜明的设计大方向,比如韩国站点设计一般比较花哨,所以动画很多,我们常常看到韩国
  • 前言:在很多应用场景下,我们不但需要堆的特性,例如快速知道数据最大值或最小值,同时还需要知道元素的排序信息,因此本节我们看看如何实现鱼和熊掌
  • 在Python中定义一个数据便在内存中开辟一片空间来存储这个变量的值,这块已经被分配的内存空间便会有一个内存地址。访问这块内存需要用到变量名
  • 一、插入排序插入排序与我们平时打扑克牌非常相似,将新摸到的牌插入到已有的牌中合适的位置,而已有的牌往往是有序的。1.1 执行流程(1)在执行
  • 有时你需临时搭建一个简单的 Web Server,但你又不想去安装 Apache、Nginx 等这类功能较复杂的 HTTP 服务程序时。这时
  • 内容摘要:本文是一篇实例讲解的文章。作为一个普通的程序员,我深知,一个优秀的例程,对于正在学习编程的人是多么的有帮助。本文中使用的例程,是一
  • 本文实例讲述了Yii2框架实现登陆添加验证码功能。分享给大家供大家参考,具体如下:models中LoginForm.phppublic $v
  • Event是Javascript中的重要事件,event代表事件的状态,专门负责对事件的处理,它的属性和方法能帮助我们完成很多和用户交互的操
  • 本文实例为大家分享了Python人脸识别的具体代码,供大家参考,具体内容如下1.利用opencv库sudo apt-get install
  • MySQL内建复制功能来优化可用性,在Soundbreak我们每天24小时不间断地播放实况音频和视频,所以对于MySQL的新增的复制特性,我
手机版 网络编程 asp之家 www.aspxhome.com