【39】多种方法实现矩阵的图像显示与保存

简介: 【39】多种方法实现矩阵的图像显示与保存

1. 从矩阵到图片的显示方法与保存


1.1 PIL实现

from PIL import Image
image= Image.fromarray(img)
image.show()  # 如果是在jupyter notebook上image就可以输出结果
image.save('image.png')


1.2 Matplotlib实现

import matplotlib.pyplot as plt
plt.imshow(image)
plt.savefig('image.png')


1.3 OpenCV实现

import cv2
cv2.imshow("image", image)
cv.imwrite('image.png', image)
cv2.waitKey(0)
cv2.destroyAllWindows()


1.4 Numpy实现

numpy可以直接将图像矩阵保存为数据,np.array数据可以通过np.save函数直接保存在磁盘上,扩展名为.npy, 通过np.load函数直接恢复


import numpy
# 会在保存的名字后面自动加上'.npy', 所以保存的全称为'array.npy'
numpy.save('array', image)   
array = numpy.load('array.npy')
# 判断保存与读取的矩阵是否一致
(array == image).all() #返回True,代表一致


1.5 Torchvision实现

  • Torchvision实现保存图像:save_image
import torch
from torchvision.utils import save_image
import numpy
# 读取图像矩阵
array = numpy.load('array.npy')
# (h,w,c) -> (c,h,w)
image = torch.FloatTensor(array).permute(2, 0, 1).unsqueeze(0)
save_image(image, 'image.png', normalize=True)   # 保存图像


image.png:

image.png


  • Torchvision实现显示图像设置:make_grid
from torchvision import datasets, transforms
from torchvision.utils import make_grid
from torch.utils.data import DataLoader
import matplotlib.pyplot as plt
import numpy as np
%matplotlib inline
# 使用matplotlib来显示图像
def show(img):
    npimg = img.numpy()
    plt.figure(figsize=(12, 12))
    plt.axis('off')   # 不显示坐标轴
    plt.imshow(np.transpose(npimg, (1,2,0)), interpolation='nearest')
# 加载mnist数据集
transform = transforms.Compose([
    transforms.ToTensor(),
])
dataset = datasets.MNIST(root='./dataset/',
                         train=True,
                         transform=transform,
                         download=False)
dataloader = DataLoader(dataset=dataset, batch_size=256, shuffle=True)
# 获取一批256个数据
image, label = iter(dataloader).next()
# 制作图像网格输出显示
batch_image = make_grid(image, nrow=16)
save_image(batch_image, 'image.jpg', normalize=True) # 保存图像
show(batch_image)                                    # 显示图像


image.jpg:

image.png

更多关于make_grid的参考资料:https://gist.github.com/anonymous/bf16430f7750c023141c562f3e9f2a91


ps: 除了make_grid,save_image;torchvision.utils中还实现了几个好用的函数


  • draw_bounding_boxes:在给定图像上绘制边界框
  • draw_segmentation_masks:在给定的 RGB 图像上绘制分割蒙版
  • draw_keypoints:在给定的 RGB 图像上绘制关键点
  • flow_to_image:将光流转换为 RGB 图像


2. 从路径到图片的显示方法


2.1 PIL实现

from PIL import Image
image = Image.open('./result.jpg')
image.show()


2.2 Matplotlib实现

import matplotlib.pyplot as plt
image = plt.imread('./result.jpg')
plt.imshow(image)


2.3 OpenCV实现

import cv2
image = cv2.imread('./result.jpg')
cv2.imshow("image", image)
cv2.waitKey(0)
cv2.destroyAllWindows()


参考资料:

1. Python中读取,显示,保存图片的方法

2. make_grid的官方测试demo


目录
相关文章
|
2月前
|
Python
python用鼠标获取图像任一点的坐标和像素值
python用鼠标获取图像任一点的坐标和像素值
45 1
|
6月前
|
定位技术
任意一张图片的CGCS2000坐标配准
任意一张图片的CGCS2000坐标配准
59 0
|
8月前
|
计算机视觉
opencv 之图像的边界填充及一些数据计算
opencv 之图像的边界填充及一些数据计算
|
11月前
|
API 计算机视觉 索引
OpenCV_02 图像的基本操作:图像IO+绘制图形+像素点+属性+图像通道+色彩空间的改变
注意:在调用显示图像的API后,要调用cv.waitKey()给图像绘制留下时间,否则窗口会出现无响应情况,并且图像无法显示出来。
80 0
利用矩阵进行平移,旋转,缩放等图像变换、创建第二个一模一样的图像并使之进行缩放等操作
利用矩阵进行平移,旋转,缩放等图像变换、创建第二个一模一样的图像并使之进行缩放等操作
|
算法
算法练习——(5)输出图形
算法练习——(5)输出图形
|
Python
【16】查看中间层特征矩阵并保存图像与参数
【16】查看中间层特征矩阵并保存图像与参数
87 0
|
计算机视觉
OpenCV 读写图像、读写像素、修改像素值(案例:图像反处理)
OpenCV 读写图像、读写像素、修改像素值(案例:图像反处理)
467 0
OpenCV 读写图像、读写像素、修改像素值(案例:图像反处理)
|
算法 计算机视觉 数据格式
用 Python 对图片主体轮廓进行提取、颜色标记、并计算区域面积
Python + Opencv2 实现轮廓提取,轮廓区域面积计算; 对图像处理时,会遇到这样一个场景:找到图像主体轮廓,这是其一,可能为了凸显轮廓,需要用指定的颜色进行标记;轮廓标记完可能任务还没有结束,还需对轮廓所勾勒的像素面积区域统计计算。
用 Python 对图片主体轮廓进行提取、颜色标记、并计算区域面积
|
计算机视觉
使用opencv读入并显示一幅彩色图像,灰度化并显示,用canny算子得到图像边缘并显示
使用opencv读入并显示一幅彩色图像,灰度化并显示,用canny算子得到图像边缘并显示
193 0
使用opencv读入并显示一幅彩色图像,灰度化并显示,用canny算子得到图像边缘并显示