Python에서 이미지를 비교하는 방법: 먼저 [pylab.imread]를 사용하여 이미지를 읽은 다음 [matplotlib.pylab - plt.imshow]를 사용하여 이미지를 표시한 다음 회색조 이미지를 RGB 이미지로 변환합니다. 이미지.
【관련 학습 권장사항: python tutorial】
Python에서 이미지를 비교하는 방법:
1. 이미지 읽기
pylab.imread 및 .이미지를 엽니다.
cv2.imread는 BGR 순서로 읽는 반면, 혼합 사용 시에는 특별한 주의가 필요합니다.
1 matplotlib.pylab
import pylab as plt import numpy as np img = plt.imread('examples.png') print(type(img), img.dtype, np.min(img), np.max(img)) [out] (<type 'numpy.ndarray'>, dtype('float32'), 0.0, 1.0) # matplotlib读取进来的图片是float,0-1
2 PIL.image.open
from PIL import Image import numpy as np img = Image.open('examples.png') print(type(img), np.min(img), np.max(img)) img = np.array(img) # 将PIL格式图片转为numpy格式 print(type(img), img.dtype, np.min(img), np.max(img)) [out] (<class 'PIL.PngImagePlugin.PngImageFile'>, 0, 255) # 注意,PIL是有自己的数据结构的,但是可以转换成numpy数组 (<type 'numpy.ndarray'>, dtype('uint8'), 0, 255) # 和用matplotlib读取不同,PIL和matlab相同,读进来图片和其存储在硬盘的样子是一样的,uint8,0-255
3 cv2 .imread
import cv2 import numpy as np img = cv2.imread('examples.png') # 默认是读入为彩色图,即使原图是灰度图也会复制成三个相同的通道变成彩色图 img_gray = cv2.imread('examples.png', 0) # 第二个参数为0的时候读入为灰度图,即使原图是彩色图也会转成灰度图 print(type(img), img.dtype, np.min(img), np.max(img)) print(img.shape) print(img_gray.shape) [out] (<type 'numpy.ndarray'>, dtype('uint8'), 0, 255) # opencv读进来的是numpy数组,类型是uint8,0-255 (824, 987, 3) # 彩色图3通道 (824, 987) # 灰度图单通道
import cv2 import pylab as plt from PIL import Image import numpy as np img_plt = plt.imread('examples.png') img_pil = Image.open('examples.png') img_cv = cv2.imread('examples.png') print(img_plt[125, 555, :]) print(np.array(img_pil)[125, 555, :] / 255.0) print(img_cv[125, 555, :] / 255.0) [out] [ 0.61176473 0.3764706 0.29019609] [ 0.61176471 0.37647059 0.29019608] [ 0.29019608 0.37647059 0.61176471] # opencv的是BGR顺序
2. 그림을 표시합니다
1, matplotlib.pylab - plt.imshow
, 이 기능은 실제로 RGB 이미지를 numpy 배열 형식으로 표시합니다.
import pylab as plt import numpy as np img = plt.imread('examples.png') plt.imshow(img) plt.show()
import pylab as plt from PIL import Image import numpy as np img = Image.open('examples.png') img_gray = img.convert('L') #转换成灰度图像 img = np.array(img) img_gray = np.array(img_gray) plt.imshow(img) # or plt.imshow(img / 255.0),matplotlib和matlab一样,如果是float类型的图像,范围是0-1才能正常imshow,如果是uint8图像,范围则需要是0-255 plt.show() plt.imshow(img_gray, cmap=plt.gray()) # 显示灰度图要设置cmap参数 plt.show() plt.imshow(Image.open('examples.png')) # 实际上plt.imshow可以直接显示PIL格式图像 plt.show()
import pylab as plt import cv2 import numpy as np img = cv2.imread('examples.png') plt.imshow(img[..., -1::-1]) # 因为opencv读取进来的是bgr顺序呢的,而imshow需要的是rgb顺序,因此需要先反过来 plt.show()
2 cv2 표시 그림
import cv2 image2=cv2.imread(r"test/aaa/0002/0002_0_1.jpg") cv2.imshow("1",image2) cv2.waitKey(0)
3. 회색조 이미지 - RGB 이미지 변환
1 PIL.Image
from PIL import Image img = Image.open('examples.png') img_gray = img.convert('L') # RGB转换成灰度图像 img_rgb = img_gray.convert('RGB') # 灰度转RGB print(img) print(img_gray) print(img_rgb) [out] <PIL.PngImagePlugin.PngImageFile image mode=RGB size=987x824 at 0x7FC2CCAE04D0> <PIL.Image.Image image mode=L size=987x824 at 0x7FC2CCAE0990> <PIL.Image.Image image mode=RGB size=987x824 at 0x7FC2CCAE0250>
2 cv2(opencv는 이미지를 읽을 때 매개변수를 통해 색상 채널을 변환할 수 있습니다. 다음은 이를 달성하는 또 다른 방법입니다.)
import cv2 import pylab as plt img = cv2.imread('examples.png') img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # BGR转灰度 img_bgr = cv2.cvtColor(img_gray, cv2.COLOR_GRAY2BGR) # 灰度转BRG img_rgb = cv2.cvtColor(img_gray, cv2.COLOR_GRAY2RGB) # 也可以灰度转RGB
4. 사진 저장
1 PIL.image - PIL 형식으로 사진 저장
from PIL import Image img = Image.open('examples.png') img.save('examples2.png') img_gray = img.convert('L') img_gray.save('examples_gray.png') # 不管是灰度还是彩色,直接用save函数保存就可以,但注意,只有PIL格式的图片能够用save函数
2 cv2.imwrite - 사진을 numpy 형식으로 저장합니다.
import cv2 img = cv2.imread('examples.png') # 这是BGR图片 cv2.imwrite('examples2.png', img) # 这里也应该用BGR图片保存,这里要非常注意,因为用pylab或PIL读入的图片都是RGB的,如果要用opencv存图片就必须做一个转换 img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) cv2.imwrite('examples_gray.png', img_gray)
더 많은 관련 학습을 보려면 php training 칼럼에 주목하세요!
위 내용은 Python에서 이미지 간의 차이점을 비교하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!