浅谈tensorflow 中的图片读取和裁剪方式


Posted in Python onJune 30, 2020

一 方式1: skimage

from skimage import data, io, transform, color 
import matplotlib.pyplot as plt 
 
# io.imread 读出的图片格式是uint8,value是numpy array 类型。
image = data.coffee()
image = io.imread(dir)
 
plt.imshow(image)
plt.show()
 
io.save('1.jpg',image) #保存图像
 
image_gray = color.rgb2gray(image) #转换为灰度图像
io.save('2.jpg',image_gray)
 
# 通过transform.resize()裁剪后的图片是以 float64的格式存储的,数值的取值范围是(0~1)
image_ = transform.resize(image,(200,200))
img = image_ * 255 #将图片的取值范围改成(0~255)
img = img.astype(np.uint8) 
img = image_ * 255 #将图片的取值范围改成(0~255)
img = img.astype(np.uint8)

二、方式2:cv2

import cv2
import matplotlib.pyplot as plt 
 
# cv2.imread读出的图片格式是uint8,value也是numpy array 类型。
# 图像数据格式是以BGR的格式进行存储的。需要将存储类型改成RGB 的形式才能正常显示原图的颜色。
image=cv2.imread(dir) 
b,g,r = cv2.split(image)  #将图像通道分离开 
rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新组合 
#image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) 也可以使用这个函数直接转换成RGB 形式 
plt.imshow(rgb_image) 
 
# 通过cv2.resize()裁剪后的图片还是以 numpy array 的方式保存的, 数值的取值范围是(0~255)
image_cv2 = cv2.resize(rgb_image)
 
image=cv2.imread(dir) 
b,g,r = cv2.split(image)  #将图像通道分离开 
rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新组合 
#image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) 也可以使用这个函数直接转换成RGB 形式 
plt.imshow(rgb_image) 

# 通过cv2.resize()裁剪后的图片还是以 numpy array 的方式保存的, 数值的取值范围是(0~255)
image_cv2 = cv2.resize(rgb_image)

补充知识:tensorflow中两种读图及裁剪图片的区别(io.imread和cv2.imread)以及(transform.resize和cv2.resize)

Tensorflow中,在训练图片数据之前,需要先对图片进行预处理,读图和裁剪是最基本的两步。常见的的读图何裁剪分别有两种方式,这里小编将和大家分享下这几种方式的实现以及他们之间的区别。

一、常见的两种读图方式 io.imread() 和 cv2.imread()

1.io.imread 读出的图片格式是uint8,value是numpy array 类型。对于RGB 图片,图像数据是以RGB 的格式进行存储的。

浅谈tensorflow 中的图片读取和裁剪方式

2.cv2.imread读出的图片格式是uint8 ,value也是numpy array 类型。唯一的区别是,图像数据格式是以BGR的格式进行存储的。需要将存储类型改成RGB 的形式才能正常显示原图的颜色。特别是制作tfrecord 时,需要将图片通道改成RGB,具体代码如下。

import cv2
import matplotlib.pyplot as plt
from skimage import transform 
import numpy as np
import skimage.io as io 
 
train_dir = 'E:/TensorFlow/Project_TF/flower_tfrecord/data/test/roses/timg.jpg'
 
'''以cv2方式读取图片'''
image=cv2.imread(train_dir)
b,g,r = cv2.split(image)  #将图像通道分离开
rgb_image = cv2.merge([r,g,b]) #以RGB的形式重新组合
 
#image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) 也可以使用这个函数直接转换成RGB 形式
plt.imshow(rgb_image)
 
'''以io.imread方式读取图片'''
#image = io.imread(train_dir) #读图并显示 
#plt.imshow(image)

二、常见的两种图片裁剪方式 cv2.resize() 和 transform.resize()

1.通过cv2.resize()裁剪后的图片还是以 numpy array 的方式保存的, 数值的取值范围是(0~255)

浅谈tensorflow 中的图片读取和裁剪方式

2.通过transform.resize()裁剪后的图片是以 float64的格式存储的,数值的取值范围是(0~1)。通常在制作tfrecord 数据集的过程中,我们需要将其转换成numpy array的形式,具体代码如下

'''以io.imread方式读取图片并使用transform形式裁剪图片'''
image = io.imread(train_dir) #读图并显示 
plt.imshow(image)
image =transform.resize(image, (208, 208))
img = image * 255 #将图片的取值范围改成(0~255)
img = img.astype(np.uint8) 
 
plt.imshow(img)

读图和裁剪图片在制作tfrecord数据集时,是很基础的步骤,在接下来,我还将进一步更新如何制作自己的tfrecord数据集,以及tfrecord的读取。如有谬误,还请大家斧正。

以上这篇浅谈tensorflow 中的图片读取和裁剪方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python中assert用法实例分析
Apr 30 Python
在Python中处理时间之clock()方法的使用
May 22 Python
python3中bytes和string之间的互相转换
Feb 09 Python
Python爬虫实例_城市公交网络站点数据的爬取方法
Jan 10 Python
python3+mysql查询数据并通过邮件群发excel附件
Feb 24 Python
Python使用MD5加密算法对字符串进行加密操作示例
Mar 30 Python
Python工厂函数用法实例分析
May 14 Python
Django csrf 验证问题的实现
Oct 09 Python
Python Opencv实现图像轮廓识别功能
Mar 23 Python
Tensorflow训练MNIST手写数字识别模型
Feb 13 Python
Python decimal模块使用方法详解
Jun 08 Python
python urllib库的使用详解
Apr 13 Python
Python openpyxl模块实现excel读写操作
Jun 30 #Python
tensorflow下的图片标准化函数per_image_standardization用法
Jun 30 #Python
Python的控制结构之For、While、If循环问题
Jun 30 #Python
关于tensorflow softmax函数用法解析
Jun 30 #Python
基于tensorflow for循环 while循环案例
Jun 30 #Python
解析Tensorflow之MNIST的使用
Jun 30 #Python
Tensorflow tensor 数学运算和逻辑运算方式
Jun 30 #Python
You might like
PHP调用三种数据库的方法(3)
2006/10/09 PHP
PHP中使用mktime获取时间戳的一个黑色幽默分析
2012/05/31 PHP
深入理解:XML与对象的序列化与反序列化
2013/06/08 PHP
PHP链接MySQL的常用扩展函数
2014/10/23 PHP
php post大量数据时发现数据丢失问题解决方法
2015/06/20 PHP
WordPress开发中的get_post_custom()函数使用解析
2016/01/04 PHP
zend framework重定向方法小结
2016/05/28 PHP
php解析base64数据生成图片的方法
2016/12/06 PHP
JS解密入门 最终变量劫持
2008/06/25 Javascript
为jquery.ui.dialog 增加“在当前鼠标位置打开”的功能
2009/11/24 Javascript
JavaScript CSS修改学习第六章 拖拽
2010/02/19 Javascript
javascript json2 使用方法
2010/03/16 Javascript
JavaScript高级程序设计(第3版)学习笔记12 js正则表达式
2012/10/11 Javascript
jQuery遍历Table应用示例
2014/04/09 Javascript
javascript实现左右控制无缝滚动
2014/12/31 Javascript
javascript计时器详解
2015/02/28 Javascript
详解js私有作用域中创建特权方法
2016/01/25 Javascript
JavaScript添加随滚动条滚动窗体的方法
2016/02/23 Javascript
jQuery+PHP实现微信转盘抽奖功能的方法
2016/05/25 Javascript
jquery实用技巧之输入框提示语句
2016/07/28 Javascript
javaScript语法总结
2016/11/25 Javascript
浅谈js在html中的加载执行顺序,多个jquery ready执行顺序
2016/11/26 Javascript
React Native 通告消息竖向轮播组件的封装
2020/08/25 Javascript
详解Angular-ui-BootStrap组件的解释以及使用
2018/07/13 Javascript
快速了解Node中的Stream流是什么
2019/02/13 Javascript
前端Electron新手入门教程详解
2019/06/21 Javascript
[01:14]TI珍贵瞬间系列(六):冠军
2020/08/30 DOTA
《Python学习手册》学习总结
2018/01/17 Python
基于numpy中的expand_dims函数用法
2019/12/18 Python
Python3 Tensorlfow:增加或者减小矩阵维度的实现
2020/05/22 Python
法国面料和小百货在线商店:Mondial Tissus
2019/03/23 全球购物
What is the purpose of Void class? Void类的作用是什么?
2016/10/31 面试题
酒店中秋节活动方案
2014/01/31 职场文书
个人安全承诺书
2014/05/22 职场文书
SQL语法CONSTRAINT约束操作详情
2022/01/18 MySQL
 Python 中 logging 模块使用详情
2022/03/03 Python