导入原有的测试图片,测试图片路径,和一些方法,显示出测试图像,测试图像路径。

from skimage import io,data,data_dir
img_rgb=data.chelsea()
io.imshow(img_rgb)
data_dir

使用打开方式的方案,将图像转为灰度图,并显示。保存图像。

img_gray=io.imread(data_dir+'/chelsea.png',as_grey=True)
io.imshow(img_gray)
io.imsave('chelsea.png',img_gray)

显示出数字图像的各种信息:

print(type(img_gray))  #显示类型
print(img_gray.shape) #显示尺寸
print(img_gray.shape[0]) #图片宽度
print(img_gray.shape[1]) #图片高度
print(img_gray.size) #显示总像素个数
print(img_gray.max()) #最大像素值
print(img_gray.min()) #最小像素值
print(img_gray.mean()) #像素平均值

提取图像的红色通道值,显示。

img_rgb_r=img_rgb[:,:,0]#选取像素值,红色单通道
io.imshow(img_rgb_r)

导入深度复制图像的方法,将图像备份,建立椒盐噪声图像。

import numpy as np
import copy as cp
img_rgb_noise = cp.deepcopy(img_rgb)
for i in range(1000):
x = np.random.randint(0,img_rgb_noise.shape[0])
y = np.random.randint(0,img_rgb_noise.shape[1])
img_rgb_noise[x,y,:] = 255
io.imshow(img_rgb_noise)

将图像切片提取,显示出部分图像。

img_rgb_cut = img_rgb[0:int(img_rgb.shape[0]/2),0:int(img_rgb.shape[1]/2),:]
io.imshow(img_rgb_cut)

将灰度图像二值化的一种方法:

import copy as cp
img_gray_binaryzation = cp.deepcopy(img_gray)
for i in range(img_gray.shape[0]):
for j in range(img_gray.shape[1]):
if img_gray_binaryzation[i,j] > 0.5 :
img_gray_binaryzation[i,j] = 1
else :
img_gray_binaryzation[i,j] = 0
io.imshow(img_gray_binaryzation)

通过判断,提取出部分符合条件的数据,将符合条件的数据进行修改,,,一个示例

import copy as cp
img_rgb_blue = cp.deepcopy(img_rgb)
reddish = img_rgb[:, :, 0] >100#建立红色通道值大于100的二维布尔数组
img_rgb_blue[reddish,0] = [0]#根据筛选条件,筛选出并将红色通道赋值为0
reddish = img_rgb[:, :, 2] >100
img_rgb_blue[reddish,2] = [0]#根据筛选条件,筛选出并将蓝色通道赋值为0
reddish.shape
io.imshow(img_rgb_blue)

图像的数据类型查看,float数据类型为0-1

img_rgb.dtype.name#查看图像的数据类型
img_gray.dtype.name
img_gray.max()

图像的数据类型转化:

from skimage import img_as_float,img_as_ubyte
arrays = img_as_ubyte(img_gray)
arrays.max()

使用color方法,完成图像的形式转化:

from skimage import color
io.imshow(color.rgb2gray(img_rgb))
io.imshow(color.convert_colorspace(img_rgb,'RGB','hsv'))

使用matplotlib中的pyplot下的imshow显示图像。

import matplotlib.pyplot as plt
dst = plt.imshow(img_rgb)#有一个AxesImage对象显示出来
plt.axis('off')
print(type(dst))

图像分割,设置标题,灰度图显示,不显示坐标的方法示例

from skimage import data
import matplotlib.pyplot as plt
img=data.astronaut()
plt.figure(num='astronaut',figsize=(8,8)) #创建一个名为astronaut的窗口,并设置大小 plt.subplot(2,2,1) #将窗口分为两行两列四个子图,则可显示四幅图片
plt.title('origin image') #第一幅图片标题
plt.imshow(img) #绘制第一幅图片 plt.subplot(2,2,2) #第二个子图
plt.title('R channel') #第二幅图片标题
plt.imshow(img[:,:,0],plt.cm.gray) #绘制第二幅图片,且为灰度图
plt.axis('off') #不显示坐标尺寸 plt.show() #显示窗口

读取某目录下的所有图像的方法,多选图像格式和路径等

import skimage.io as io
from skimage import data_dir
str=data_dir + '/*.png'
str+=';'+data_dir + '/*.jpg'
coll = io.ImageCollection(str)
print(len(coll))
io.imshow(coll[0])

io.ImageCollection()这个函数省略第二个参数,就是批量读取。将批量读取修改为其它批量操作,如批量转换为灰度图,修改图像大小

然后批量保存图像:

from skimage import data_dir,io,transform,color
import numpy as np
def convert_gray(f):
rgb=io.imread(f) #依次读取rgb图片
gray=color.rgb2gray(rgb) #将rgb图片转换成灰度图
dst=transform.resize(gray,(256,256)) #将灰度图片大小转换为256*256
return dst
str=data_dir+'/*.png'
str+=';'+data_dir + '/*.jpg'
coll = io.ImageCollection(str,load_func=convert_gray)#修改默认批量操作为转化为灰度图
for i in range(len(coll)):
io.imsave('./data/'+np.str(i)+'.jpg',coll[i]) #循环保存图片

python的数字图像处理学习(1)的更多相关文章

  1. python的数字图像处理学习(3)

    高级滤波: from skimage import data,color,data_dir import matplotlib.pyplot as plt from skimage.morpholog ...

  2. python的数字图像处理学习(2)

    图像的重定义大小,图像的缩扩,图像的旋转: from skimage import transform,data import matplotlib.pyplot as plt img = data. ...

  3. 【笔记】基于Python的数字图像处理

    [博客导航] [Python相关] 前言 基于Python的数字图像处理,离不开相关处理的第三方库函数.搜索网络资源,列出如下资源链接. Python图像处理库到底用哪家 python计算机视觉编程— ...

  4. 数字图像处理学习笔记之一 DIP绪论与MATLAB基础

    写在前面的话 数字图像处理系列的学习笔记是作者结合上海大学计算机学院<数字图像处理>课程的学习所做的笔记,使用参考书籍为<冈萨雷斯数字图像处理(第二版)(MATLAB版)>,同 ...

  5. MATLAB数字图像处理学习笔记

    我们都知道一幅图片就相当于一个二维数组,可以用一个矩阵来表示,而MATLAB可以说就是为矩阵运算而生的,所以学习图像处理,学习MATLAB势在必行! 一. MATLAB基础知识 1. 读取图像 %im ...

  6. 初始----python数字图像处理--:环境安装与配置

    一提到数字图像处理编程,可能大多数人就会想到matlab,但matlab也有自身的缺点: 1.不开源,价格贵 2.软件容量大.一般3G以上,高版本甚至达5G以上. 3.只能做研究,不易转化成软件. 因 ...

  7. 数字图像处理(一)之灰度转换和卷积python实现

    使用Python实现数字图像处理中如下功能: 彩色图像转成灰度图像 实现图像的相关&卷积操作 实现图像的高斯核卷积 使用的库和python版本如下: imageio:2.9.0 用于读取磁盘中 ...

  8. python数字图像处理(17):边缘与轮廓

    在前面的python数字图像处理(10):图像简单滤波 中,我们已经讲解了很多算子用来检测边缘,其中用得最多的canny算子边缘检测. 本篇我们讲解一些其它方法来检测轮廓. 1.查找轮廓(find_c ...

  9. python数字图像处理(1):环境安装与配置

    一提到数字图像处理编程,可能大多数人就会想到matlab,但matlab也有自身的缺点: 1.不开源,价格贵 2.软件容量大.一般3G以上,高版本甚至达5G以上. 3.只能做研究,不易转化成软件. 因 ...

随机推荐

  1. WdatePicker控件中日期的范围选择

    1.开始日期不能大于结束日期,结束日期只能选择今天之前(不包括今天) <asp:TextBox ID="T_CREATION_DATE_Start" Width=" ...

  2. Angular之RouterModule的forRoot与forChild

    Angular 提供了一种方式来把服务提供商从模块中分离出来,以便模块既可以带着 providers 被根模块导入,也可以不带 providers 被子模块导入. 区别: `forRoot` crea ...

  3. 给自己的博客上添加个flash宠物插件

    前言 最近在一些博主的博客上看到一些小宠物的挂件,很有趣,访客到了网站后可以耍耍小宠物,增加网站的趣味性,在功能强大的博客系统上看到有这样的小宠物挂件还是蛮有趣的. 正文 下面就简单介绍下如何在博客园 ...

  4. 《centos系列》ubuntu终端链接centos服务器

    首先你得知道centos的账户密码:如果你不知道可以直接在centos下使用root用户: passwd 用户名 直接更新用户的密码. 然后在ubuntu终端(前提是已经安装了ssh): ssh ad ...

  5. 27-java String 之间比较的幺蛾子

    仔细看啊, 他有双引号啊!!!!

  6. css兼容性写法大全

    淘宝初始化代码 body, h1, h2, h3, h4, h5, h6, hr, p, blockquote, dl, dt, dd, ul, ol, li, pre, form, fieldset ...

  7. Android Studio 检查Top Activity

    public void CheckTop(String packagename,int casenum) { Context context = getBaseContext(); ActivityM ...

  8. C#中泛型的解释(object,list,var,dynamic的区别)

    泛型是 2.0 版 C# 语言和公共语言运行库 (CLR) 中的一个新功能.泛型将类型参数的概念引入 .NET Framework,类型参数使得设计如下类和方法成为可能:这些类和方法将一个或多个类型的 ...

  9. YII2中actions的作用与使用

    我们常在控制器中看到一个actions的方法,这个方法具体的作用是共用一些功能相同的action,方便调用. 当然我们也可以自已写一些action来进行调用.在项目目录下创建common目录,并创建T ...

  10. 【gRPC使用问题3】生成出来无法识别Google.Api.AnnotationsReflection.Descriptor

    1.问题截图: 2.解决方案: Install the package "Google.Api.Gax.Grpc". From the Package Manager Consol ...