使用OpenCV和PIL库读取图片的区别

OpenCV 和 PIL(Pillow)是两个不同的图像处理库,它们使用不同的数据结构来表示图像。

OpenCV 格式图像:
OpenCV 中的图像通常表示为 NumPy 数组。这些数组可以是多维的,例如对于彩色图像,它们是三维数组,其中包含行、列和通道。OpenCV 默认使用 BGR(蓝、绿、红)通道顺序排列图像数据。例如,对于一个彩色图像,它可以被表示为一个形状为 (height, width, 3) 的 NumPy 数组,分别对应图像的高度、宽度和通道数(红、绿、蓝)。

PIL 格式图像:
PIL(Pillow)库中的图像是 Image 对象,它提供了一系列方法和属性来处理图像。PIL 图像对象也可以从文件中加载,然后在 Python 中进行操作。PIL 使用 RGB(红、绿、蓝)通道顺序排列图像数据。

一张原始的图片通常不是特定于任何库的格式。图片的原始表示通常是存储在磁盘上的未经过解码或解析的二进制数据。当我们使用某个库(比如 OpenCV 或 PIL)加载图像时,这个图像会被解码并转换为相应库支持的格式,然后我们可以在代码中进行处理、显示或者保存。

代码如下:
使用OpenCV库:

import cv2

# 读取图像
image_path = 'your_image_path.jpg'  # 替换成你的图片路径
image = cv2.imread(image_path)

# 获取图像的像素值大小
height, width, channels = image.shape
print(f"图像宽度为:{width} 像素")
print(f"图像高度为:{height} 像素")

使用PIL库:

import cv2

# 读取图像
from PIL import Image

# 打开图像
image_path = 'your_image_path.jpg'  # 替换成你的图片路径
image = Image.open(image_path)

# 获取图像的像素值大小
width, height = image.size
print(f"图像宽度为:{width} 像素")
print(f"图像高度为:{height} 像素")


你可能感兴趣的:(opencv,人工智能,计算机视觉)