Python Pillow-퀵 가이드
오늘날의 디지털 세계에서 우리는 많은 디지털 이미지를 접하게됩니다. Python 프로그래밍 언어로 작업하는 경우 디지털 이미지에 이미지 처리 기능을 추가하기 위해 많은 이미지 처리 라이브러리를 제공합니다.
가장 일반적인 이미지 처리 라이브러리는 OpenCV, PIL (Python Imaging Library), Scikit-image, Pillow입니다. 그러나이 튜토리얼에서는Pillow module 이 모듈의 다양한 기능을 탐색하려고합니다.
Pillow는 PIL (Python Image Library) 위에 구축되었습니다. PIL은 Python에서 이미지 처리를위한 중요한 모듈 중 하나입니다. 그러나 PIL 모듈은 2011 년부터 지원되지 않으며 python 3을 지원하지 않습니다.
Pillow 모듈은 더 많은 기능을 제공하고 모든 주요 운영 체제에서 실행되며 python 3을 지원합니다. "jpeg", "png", "bmp", "gif", "ppm", "tiff"와 같은 다양한 이미지를 지원합니다. 필로우 모듈을 사용하여 디지털 이미지에서 거의 모든 작업을 수행 할 수 있습니다. 포인트 연산, 내장 된 컨볼 루션 커널을 사용한 이미지 필터링 및 색 공간 변환을 포함한 기본 이미지 처리 기능 외에도.
이미지 아카이브
Python Imaging Library는 이미지 보관 및 일괄 처리 애플리케이션에 가장 적합합니다. 파이썬 베개 패키지는 썸네일 생성, 한 형식에서 다른 형식으로 변환, 이미지 인쇄 등에 사용할 수 있습니다.
이미지 디스플레이
Tk PhotoImage, BitmapImage 및 Windows DIB 인터페이스를 사용하여 이미지를 표시 할 수 있으며, 이는 PythonWin 및 기타 Windows 기반 툴킷 및 기타 많은 GUI (그래픽 사용자 인터페이스) 툴킷과 함께 사용할 수 있습니다.
디버깅 목적으로 외부 디스플레이 유틸리티를 호출하는 디스크에 이미지를 저장하는 show () 메서드가 있습니다.
이미지 처리
Pillow 라이브러리에는 모든 기본 이미지 처리 기능이 포함되어 있습니다. 이미지 크기 조정, 회전 및 변형을 수행 할 수 있습니다.
Pillow 모듈을 사용하면 히스토그램 방법을 사용하여 이미지에서 일부 통계 데이터를 가져올 수 있으며 나중에 통계 분석 및 자동 대비 향상에 사용할 수 있습니다.
이 장에서는 컴퓨터에 베개 패키지를 설치하는 방법에 대해 설명합니다.
베개 패키지 설치는 특히 pip를 사용하여 설치하는 경우 매우 쉽습니다.
pip를 사용하여 Pillow 설치
pip를 사용하여 베개를 설치하려면 명령 프롬프트에서 아래 명령을 실행하십시오.
python -m pip install pip
python -m pip install pillow
pip와 pillow가 이미 컴퓨터에 설치되어 있다면 위의 명령어는 단순히 'requirement already satisfied'아래와 같이-
이미지를 표시하기 위해 베개 라이브러리는 그 안에 이미지 클래스를 사용하고 있습니다. Pillow 패키지 내부의 이미지 모듈에는 이미지로드 또는 새 이미지 생성 등과 같은 몇 가지 중요한 내장 기능이 포함되어 있습니다.
이미지 열기, 회전 및 표시
이미지를로드하려면 베개에서 이미지 모듈을 가져 와서 Image.open(), 이미지 파일 이름을 전달합니다.
Pillow 모듈을 호출하는 대신 PIL (Python Imaging Library)이라는 이전 모듈과 역 호환되도록 PIL 모듈을 호출합니다. 이것이 우리 코드가“from PIL import Image” 대신에 “from Pillow import Image”.
다음으로, 우리는 다음을 호출하여 이미지를로드 할 것입니다. Image.open() function, Image 객체 데이터 유형의 값을 반환합니다. 이미지 개체에 대한 수정 사항은 다음을 사용하여 이미지 파일에 저장할 수 있습니다.save()방법. 사용하여받은 이미지 객체Image.open(), 나중에이 Image 객체에 대한 크기 조정, 자르기, 그리기 또는 기타 이미지 조작 메서드 호출에 사용할 수 있습니다.
예
다음 예제는 파이썬 베개를 사용하여 이미지의 회전을 보여줍니다-
from PIL import Image
#Open image using Image module
im = Image.open("images/cuba.jpg")
#Show actual Image
im.show()
#Show rotated Image
im = im.rotate(45)
im.show()
산출
위 프로그램을 Example.py로 저장하고 실행하면 다음과 같이 표준 PNG 디스플레이 유틸리티를 사용하여 원본과 회전 된 이미지를 표시합니다.
Actual image
Rotated image (45 degrees)
이미지 모듈의 속성
Image 클래스의 인스턴스에는 몇 가지 특성이 있습니다. 예를 들어 그들 중 몇 가지를 이해하려고 노력합시다-
Image.filename
이 함수는 이미지의 파일 이름 또는 경로를 가져 오는 데 사용됩니다.
>>>image = Image.open('beach1.jpg')
>>> image.filename
'beach1.jpg'
Image.format
이 함수는 'JPEG', 'BMP', 'PNG'등과 같은 이미지 파일의 파일 형식을 반환합니다.
>>> image = Image.open('beach1.jpg')
>>>
>>> image.format
'JPEG'
Image.mode
이미지에서 사용하는 픽셀 형식을 가져 오는 데 사용됩니다. 일반적인 값은 "1", "L", "RGB"또는 "CMYK"입니다.
>>> image.mode
'RGB'
이미지 크기
이미지의 높이와 무게로 구성된 튜플을 반환합니다.
>>> image.size
(1280, 721)
Image.width
이미지의 너비 만 반환합니다.
>>> image.width
1280
Image.height
이미지의 높이 만 반환합니다.
>>> image.height
721
Image.info
이미지와 관련된 데이터를 보유한 사전을 반환합니다.
>>> image.info
{'jfif': 257, 'jfif_version': (1, 1), 'dpi': (300, 300), 'jfif_unit': 1, 'jfif_density': (300, 300), 'exif': b"Exif\x00\x00MM\x00*\x00\x00\x00
....
....
\xeb\x00\x00'\x10\x00\x00\xd7\xb3\x00\x00\x03\xe8"}
Image.palette
색상 팔레트 테이블이 있으면 반환합니다.
>>> image.palette
Output above − 없음
이 장에서는 Pillow에서 이미지를 읽고 저장하는 방법을 포함한 주제에 대해 자세히 설명합니다.
이미지 읽기
베개 라이브러리를 사용하여 이미지를 읽고 쓰는 것은 매우 간단합니다. PIL.Image module function.
통사론
Image.open(fp, mode=’r’)
어디
fp− 파일 이름 (문자열), pathlib.Path 객체 또는 파일 객체. 파일 객체는 read (), seek () 및 tell () 메서드를 구현해야하며 바이너리 모드에서 열어야합니다.
mode − 선택적 인수입니다. 주어진 경우 'r'이어야합니다.
Return value − 이미지 객체.
Error − 파일을 찾을 수 없거나 이미지를 열어 식별 할 수없는 경우.
예
다음은 모든 형식의 이미지를 여는 매우 간단한 예입니다 (우리는.jpg), 창에 표시 한 다음 다른 파일 형식 (.txt)으로 저장 (기본 위치)합니다.png).
from PIL import Image
image = Image.open('beach1.jpg')
image.show()
image.save('beach1.bmp')
image1 = Image.open('beach1.bmp')
image1.show()
위의 예에서는 PIL 라이브러리에서 이미지 모듈을 가져온 다음 Image.open()이미지 개체 데이터 유형을 반환하는 디스크에서 이미지를 읽는 함수입니다. 파일 내용을보고 파일 유형을 자동으로 결정합니다. 읽기를 위해open() 함수는 filename(string), ㅏ path object 또는 image(file) 목적.
따라서 open () 함수를 사용하여 실제로 이미지를 읽습니다. Image.open ()은 이미지를 읽고 이미지에서 모든 관련 정보를 가져옵니다.
산출
위의 프로그램을 Example.py로 저장하고 실행하면 다음과 같이 표준 PNG 디스플레이 유틸리티를 사용하여 원본 (.jpg) 및 다시 저장된 (.bmp) 이미지를 표시합니다.
Actual image
Resaved image (.bmp)
이미지 저장
save () 함수는 이미지를 파일에 씁니다. 읽기 (open () 함수)와 마찬가지로 save () 함수는 쓰기 위해 열린 파일 이름, 경로 객체 또는 파일 객체를받습니다.
통사론
Image.save(fp, format=None, **params)
어디,
fp − 파일 이름 (문자열), pathlib.Path 객체 또는 파일 객체.
format− 선택적 형식 재정의. 생략하면 사용할 형식은 파일 이름 확장자에서 결정됩니다. 파일 이름 대신 파일 개체가 사용 된 경우이 매개 변수는 항상 사용해야합니다.
options − 이미지 작성자에 대한 추가 매개 변수.
Return value − 없음
KeyError − 파일 이름에서 출력 형식을 확인할 수없는 경우 형식 옵션을 사용하여이 문제를 해결하십시오.
IOError − 파일을 쓸 수없는 경우 파일이 생성되었을 수 있으며 일부 데이터가 포함될 수 있습니다.
간단히 말해서 위의 구문은 주어진 파일 이름으로 이미지를 저장합니다. 형식이 지정되지 않으면 현재 파일 이름 확장자를 기반으로합니다. 작성자에게 추가 지침을 제공하기 위해 키워드 옵션을 사용합니다.
image.save('beach1.bmp')
위의 예에서는 이미지 유형을 결정하기 위해 파일 확장자를 기반으로 파일을 저장합니다. 예를 들어, 위의 경우 현재 작업 디렉토리에 bmp 파일이 생성됩니다.
두 번째 매개 변수로 파일 유형을 명시 적으로 지정할 수도 있습니다.
image.save('beach1.gif', 'GIF')
때로는 모든 이미지의 높이와 너비가 동일해야합니다. 이를 달성하는 한 가지 방법은 pillow 라이브러리의 thumbnail () 함수를 사용하여 모든 이미지의 썸네일을 만드는 것입니다.
이 메소드는 이미지 자체의 썸네일 버전을 포함하도록 수정하며 이미지의 크기는 주어진 크기보다 크지 않습니다.
이 메서드는 이미지의 측면을 유지하기 위해 적절한 축소판 크기를 계산하고 draft () method 파일 판독기를 구성하고 (해당되는 경우) 마지막으로 이미지 크기를 조정합니다.
통사론
Image.thumbnail(size, resample=3)
어디,
Size − 필요한 크기
Resample− 선택적 리샘플링 필터. PIL.Image.NEAREST, PIL.Image.BILINEAR, PIL.Image.BICUBIC 또는 PIL.Image.LANCZOS 중 하나 일 수 있습니다. 생략하면 기본값은 PIL.Image.BICUBIC입니다.
Returns − 없음
예
다음 예제는 파이썬 베개를 사용하여 썸네일 생성을 보여줍니다.
from PIL import Image
def tnails():
try:
image = Image.open('images/cat.jpg')
image.thumbnail((90,90))
image.save('images/thumbnail.jpg')
image1 = Image.open('images/thumbnail.jpg')
image1.show()
except IOError:
pass
tnails()
산출
위 프로그램을 Example.py로 저장하고 실행하면 다음과 같이 기본 PNG 표시 유틸리티를 사용하여 생성 된 썸네일을 표시합니다.
Original image
Output image
Pillow 패키지를 사용하면 이미지를 다른 이미지에 붙여 넣을 수 있습니다. merge () 함수는 모드와 이미지 튜플을 매개 변수로 받아 단일 이미지로 결합합니다.
통사론
Image.merge(mode, bands)
어디,
mode − 출력 이미지에 사용할 모드.
bands − 출력 이미지의 각 대역에 대해 하나의 단일 대역 이미지를 포함하는 시퀀스. 모든 밴드의 크기는 동일해야합니다.
Return value − 이미지 개체.
merge () 함수를 사용하면 이미지의 RGB 밴드를 다음과 같이 병합 할 수 있습니다.
from PIL import Image
image = Image.open("beach1.jpg")
r, g, b = image.split()
image.show()
image = Image.merge("RGB", (b, g, r))
image.show()
위의 코드를 실행하면 아래와 같이 RGB 밴드를 병합하여 원본 이미지와 이미지를 볼 수 있습니다.
입력 이미지
출력 이미지
두 이미지 병합
같은 방식으로 두 개의 다른 이미지를 병합하려면 다음을 수행해야합니다.
open () 함수를 사용하여 필요한 이미지에 대한 이미지 객체를 만듭니다.
두 이미지를 병합하는 동안 두 이미지의 크기가 같은지 확인해야합니다. 따라서 두 이미지의 각 크기를 가져오고 필요한 경우 그에 따라 크기를 조정하십시오.
Image.new () 함수를 사용하여 빈 이미지를 만듭니다.
paste () 함수를 사용하여 이미지를 붙여 넣습니다.
save () 및 show () 함수를 사용하여 결과 이미지를 저장하고 표시합니다.
예
다음 예제는 파이썬 베개를 사용하여 두 이미지를 병합하는 방법을 보여줍니다.
from PIL import Image
#Read the two images
image1 = Image.open('images/elephant.jpg')
image1.show()
image2 = Image.open('images/ladakh.jpg')
image2.show()
#resize, first image
image1 = image1.resize((426, 240))
image1_size = image1.size
image2_size = image2.size
new_image = Image.new('RGB',(2*image1_size[0], image1_size[1]), (250,250,250))
new_image.paste(image1,(0,0))
new_image.paste(image2,(image1_size[0],0))
new_image.save("images/merged_image.jpg","JPEG")
new_image.show()
산출
위 프로그램을 Example.py로 저장하고 실행하면 다음과 같이 표준 PNG 표시 유틸리티를 사용하여 두 개의 입력 이미지와 병합 된 이미지를 표시합니다.
입력 이미지 1
입력 이미지 2
병합 된 이미지
이미지에 필터를 적용하여 이미지의 노이즈 수준을 줄여 이미지를 흐리게 처리 할 수 있습니다. 이미지 블러 링은 이미지 처리의 중요한 측면 중 하나입니다.
그만큼 ImageFilter classPillow 라이브러리에서는 몇 가지 표준 이미지 필터를 제공합니다. 이미지 필터는 다음을 호출하여 이미지에 적용 할 수 있습니다.filter() method ImageFilter 클래스에 정의 된 필수 필터 유형이있는 Image 객체의
이미지를 흐리게하는 데 사용되는 다양한 기술이 있으며 아래에서 언급 한 기술에 대해 논의 할 것입니다.
단순 흐림
박스 블러
가우스 흐림
이 세 가지 기술은 모두 이미지에 필터를 적용하기 위해 'Image.filter ()'메소드를 사용할 것입니다.
단순 흐림
특정 커널 또는 컨볼 루션 행렬을 통해 지정된대로 이미지에 흐림 효과를 적용합니다.
통사론
filter(ImageFilter.BLUR)
예
#Import required Image library
from PIL import Image, ImageFilter
#Open existing image
OriImage = Image.open('images/boy.jpg')
OriImage.show()
blurImage = OriImage.filter(ImageFilter.BLUR)
blurImage.show()
#Save blurImage
blurImage.save('images/simBlurImage.jpg')
실행시 위의 예는 두 개의 표준 PNG 디스플레이 유틸리티 창 (이 경우 windows Photos 앱).
Original image
Blurred image
박스 블러
이 필터에서는 '반경'을 매개 변수로 사용합니다. 반경은 흐림 값에 정비례합니다.
통사론
ImageFilter.BoxBlur(radius)
어디,
Radius − 한 방향으로 상자의 크기.
Radius 0 − 흐릿함이 없음을 의미하며 동일한 이미지를 반환합니다.
RRadius 1 & minnus; 각 방향으로 1 픽셀, 즉 총 9 픽셀을 사용합니다.
예
#Import required Image library
from PIL import Image,
#Open existing image
OriImage = Image.open('images/boy.jpg')
OriImage.show()
#Applying BoxBlur filter
boxImage = OriImage.filter(ImageFilter.BoxBlur(5))
boxImage.show()
#Save Boxblur image
boxImage.save('images/boxblur.jpg')
산출
실행시 위의 예제는 두 개의 표준 PNG 디스플레이 유틸리티 창 (이 경우 Windows 사진 앱)을 생성합니다.
Original image
Blurred image
가우스 흐림
이 필터는 또한 매개 변수 반경을 사용하며 일부 알고리즘 변경으로 박스 블러와 동일한 작업을 수행합니다. 요컨대, 반경 값을 변경하면 'Gaussianblur'이미지의 강도가 달라집니다.
통사론
ImageFilter.GaussianBlur(radius=2)
어디,
반경 – 블러 반경
예
#Import required Image library
from PIL import Image, ImageFilter
#Open existing image
OriImage = Image.open('images/boy.jpg')
OriImage.show()
#Applying GaussianBlur filter
gaussImage = OriImage.filter(ImageFilter.GaussianBlur(5))
gaussImage.show()
#Save Gaussian Blur Image
gaussImage.save('images/gaussian_blur.jpg')
산출
실행시 위의 예는 두 개의 표준 PNG 디스플레이 유틸리티 창 (이 경우 windows Photos 앱).
Original image
Blurred image
자르기는 이미지에서 원하지 않는 부분을 제거하고 필요한 기능을 이미지에 추가하는 이미지 처리의 중요한 작업 중 하나입니다. 이미지 업로드를 위해 웹 애플리케이션에서 널리 사용되는 프로세스입니다.
Pillow에서 이미지 클래스의 crop () 함수를 사용하려면 부분을 직사각형으로 잘라야합니다. 이미지에서 잘라낼 사각형 부분은 4 개의 요소를 가진 튜플로 지정되고 잘라낸 이미지의 사각형 부분을 이미지 개체로 반환합니다.
예
다음 예제는 파이썬 베개를 사용하여 이미지를 회전하는 방법을 보여줍니다.
#Import required Image library
from PIL import Image
#Create an Image Object from an Image
im = Image.open('images/elephant.jpg')
#Display actual image
im.show()
#left, upper, right, lowe
#Crop
cropped = im.crop((1,2,300,300))
#Display the cropped portion
cropped.show()
#Save the cropped image
cropped.save('images/croppedBeach1.jpg')
산출
위 프로그램을 Example.py로 저장하고 실행하면 다음과 같이 표준 PNG 디스플레이 유틸리티를 사용하여 원본 이미지와 잘린 이미지를 표시합니다.
원본 이미지
잘린 이미지
Python 이미지 처리 라이브러리를 사용하여 이미지 작업을하는 동안 기존 이미지에서 더 많은 통찰력을 얻거나 가시성을 향상시키기 위해 또는 요구 사항으로 인해 기존 이미지를 뒤집어 야하는 경우가 있습니다.
베개 라이브러리의 이미지 모듈을 사용하면 이미지를 매우 쉽게 뒤집을 수 있습니다. 이미지를 뒤집기 위해 이미지 모듈의 전치 (메소드) 기능을 사용할 것입니다. 'transpose ()'가 지원하는 가장 일반적으로 사용되는 방법은 다음과 같습니다.
Image.FLIP_LEFT_RIGHT − 이미지를 수평으로 뒤집기
Image.FLIP_TOP_BOTTOM − 이미지를 수직으로 뒤집기
Image.ROTATE_90 − 각도를 지정하여 이미지 회전
예 1 : 가로로 뒤집힌 이미지
다음 Python 예제는 이미지를 읽고 수평으로 뒤집고 표준 PNG 디스플레이 유틸리티를 사용하여 원본과 뒤집힌 이미지를 표시합니다.
# import required image module
from PIL import Image
# Open an already existing image
imageObject = Image.open("images/spiderman.jpg")
# Do a flip of left and right
hori_flippedImage = imageObject.transpose(Image.FLIP_LEFT_RIGHT)
# Show the original image
imageObject.show()
# Show the horizontal flipped image
hori_flippedImage.show()
산출
Original image
Flipped image
예 2 : 수직으로 뒤집힌 이미지
다음 Python 예제는 이미지를 읽고 수직으로 뒤집고 표준 PNG 디스플레이 유틸리티를 사용하여 원본과 뒤집힌 이미지를 표시합니다.
# import required image module
from PIL import Image
# Open an already existing image
imageObject = Image.open("images/spiderman.jpg")
# Do a flip of left and right
hori_flippedImage = imageObject.transpose(Image.FLIP_LEFT_RIGHT)
# Show the original image
imageObject.show()
# Show vertically flipped image
Vert_flippedImage = imageObject.transpose(Image.FLIP_TOP_BOTTOM)
Vert_flippedImage.show()
산출
Original Image
Flipped Image
예 3 : 특정 각도로 이미지 회전
다음 Python 예제는 이미지를 읽고, 지정된 각도로 회전하고, 표준 PNG 디스플레이 유틸리티를 사용하여 원본과 회전 된 이미지를 표시합니다.
# import required image module
from PIL import Image
# Open an already existing image
imageObject = Image.open("images/spiderman.jpg")
# Do a flip of left and right
hori_flippedImage = imageObject.transpose(Image.FLIP_LEFT_RIGHT)
# Show the original image
imageObject.show()
#show 90 degree flipped image
degree_flippedImage = imageObject.transpose(Image.ROTATE_90)
degree_flippedImage.show()
산출
Original Image
Rotated Image
대부분의 디지털 이미지는 픽셀의 2 차원 평면이며 너비와 높이가 있습니다. 베개 라이브러리의 이미지 모듈에는 속성 크기가 있습니다. 이 튜플은 이미지의 너비와 높이로 구성됩니다. 이미지 크기를 조정하려면 너비와 높이를 제공하여 베개 이미지 클래스의 resize () 메서드를 호출합니다.
크기 조정 된 이미지 크기 조정 및 저장
크기 조정 및 크기 조정 된 이미지를 저장하는 프로그램은 다음과 같습니다.
#Import required Image library
from PIL import Image
#Create an Image Object from an Image
im = Image.open("images/cat.jpg")
#Display actual image
im.show()
#Make the new image half the width and half the height of the original image
resized_im = im.resize((round(im.size[0]*0.5), round(im.size[1]*0.5)))
#Display the resized imaged
resized_im.show()
#Save the cropped image
resized_im.save('resizedBeach1.jpg')
산출
위 프로그램을 Example.py로 저장하고 실행하면 다음과 같이 표준 PNG 디스플레이 유틸리티를 사용하여 원본 이미지와 크기가 조정 된 이미지를 표시합니다.
Original Image
Resized Image
온라인 사진 중 일부에 워터 마크가 표시되어 있습니다. 워터 마크는 이미지를 오용으로부터 보호하는 더 좋은 방법 중 하나입니다. 또한 사진이 오용되는 것을 방지하기 위해 소셜 미디어에 공유하기 전에 크리에이티브 사진에 워터 마크를 추가하는 것이 좋습니다.
워터 마크는 일반적으로 사진을 찍은 사람 또는 사진에 대한 권리를 소유 한 사람을 식별하는 텍스트 또는 로고가 사진에 표시됩니다.
Pillow 패키지를 사용하면 이미지에 워터 마크를 추가 할 수 있습니다. 이미지에 워터 마크를 추가하려면“Image”, “ImageDraw” 과 “ImageFont” 베개 패키지의 모듈.
'ImageDraw'모듈은 신규 또는 기존 이미지에 2D 그래픽을 그리는 기능을 추가합니다. 'ImageFont'모듈은 비트 맵, TrueType 및 OpenType 글꼴 파일을로드하는 데 사용됩니다.
예
다음 파이썬 프로그램은 파이썬 베개를 사용하여 이미지에 워터 마크를 추가하는 방법을 보여줍니다.
#Import required Image library
from PIL import Image, ImageDraw, ImageFont
#Create an Image Object from an Image
im = Image.open('images/boy.jpg')
width, height = im.size
draw = ImageDraw.Draw(im)
text = "sample watermark"
font = ImageFont.truetype('arial.ttf', 36)
textwidth, textheight = draw.textsize(text, font)
# calculate the x,y coordinates of the text
margin = 10
x = width - textwidth - margin
y = height - textheight - margin
# draw watermark in the bottom right corner
draw.text((x, y), text, font=font)
im.show()
#Save watermarked image
im.save('images/watermark.jpg')
산출
다음은 입력 이미지라고 가정합니다. boy.jpg 폴더 이미지에 있습니다.
위 프로그램을 실행 한 후 출력 폴더를 살펴보면 아래와 같이 워터 마크가있는 결과 watermark.jpg 파일을 볼 수 있습니다.
그만큼 ImageFilter moduleImage.filter () 메서드와 함께 사용한 미리 정의 된 필터 집합에 대한 정의가 포함되어 있습니다. 이 필터는 이미지의 모양과 느낌을 변경하는 데 사용됩니다.
예
아래 예는 이미지 필터링-
from PIL import Image, ImageFilter
im = Image.open('jungleSaf2.jpg')
im1 = im.filter(ImageFilter.BLUR)
im1.show()
im2 = im.filter(ImageFilter.MinFilter(3))
im2.show()
im3 = im.filter(ImageFilter.MinFilter) # same as MinFilter(3)
im3.show()
위의 프로그램에서 우리는 MinFilter()최소 필터를 만드는 데 사용되는 메서드입니다. 주어진 크기의 창에서 가장 낮은 픽셀 값을 선택합니다.
ImageFilter.MinFilter(size=3)
어디,
size − 커널 크기 (픽셀 단위).
산출
위 프로그램을 저장하고 실행하면 다음과 같이 표준 PNG 표시 유틸리티를 사용하여 원본 이미지, 흐릿한 이미지, MinFilter로 흐릿한 이미지를 보여줍니다.
Original Image
Blurred Image
Image blurred with mini filter
필터
베개 라이브러리의 현재 버전은 아래에 언급 된 사전 정의 된 이미지 향상 필터 세트를 제공합니다.
BLUR
CONTOUR
DETAIL
EDGE_ENHANCE
EDGE_ENHANCE_MORE
EMBOSS
FIND_EDGES
SHARPEN
SMOOTH
SMOOTH_MORE
예
다음 파이썬 예제는 이미지에 흐림 필터를 적용하여 저장하고 표준 PNG 디스플레이 유틸리티를 사용하여 표시합니다.
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(BLUR)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
같은 방식으로 image.filter() 메서드는 다음 매개 변수 중 하나를 전달하여 각 출력을 얻을 수 있습니다.
CONTOUR
DETAIL
EDGE_ENHANCE
EDGE_ENHANCE_MORE
EMBOSS
FIND_EDGES
SMOOTH
SMOOTH_MORE
SHARPEN
Python img.filter (CONTOUR) 메서드
다음 파이썬 예제는 주어진 이미지에 CONTOUR 필터를 적용합니다.
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(CONTOUR)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
Python img.filter (DETAIL) 메서드
다음 파이썬 예제는 주어진 이미지에 DETAIL 필터를 적용합니다.
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(DETAIL)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
Python img.filter (EDGE_ENHANCE) 메서드
다음 파이썬 예제는 주어진 이미지에 EDGE_ENHANCE 필터를 적용합니다-
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(EDGE_ENHANCE)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
Python img.filter (EDGE_ENHANCE_MORE) 메서드
다음 파이썬 예제는 주어진 이미지에 EDGE_ENHANCE_MORE 필터를 적용합니다.
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(EDGE_ENHANCE_MORE)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
Python img.filter (EMBOSS) 메서드
다음 파이썬 예제는 주어진 이미지에 EMBOSS 필터를 적용합니다.
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(EMBOSS)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
Python img.filter (FIND_EDGES) 메서드
다음 파이썬 예제는 주어진 이미지에 FIND_EDGES 필터를 적용합니다.
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(FIND_EDGES)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
Python img.filter (SMOOTH) 메서드
다음 파이썬 예제는 주어진 이미지에 SMOOTH 필터를 적용합니다.
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(SMOOTH)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
Python img.filter (SHARPEN) 메서드
다음 파이썬 예제는 주어진 이미지에 SHARPEN 필터를 적용합니다.
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(SHARPEN)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
다음 파이썬 예제는 주어진 이미지에 SHARPEN 필터를 적용합니다.
예
#Import required image modules
from PIL import Image, ImageFilter
#Import all the enhancement filter from pillow
from PIL.ImageFilter import (
BLUR, CONTOUR, DETAIL, EDGE_ENHANCE, EDGE_ENHANCE_MORE,
EMBOSS, FIND_EDGES, SMOOTH, SMOOTH_MORE, SHARPEN
)
#Create image object
img = Image.open('images/cat.jpg')
#Applying the blur filter
img1 = img.filter(SHARPEN)
img1.save('images/ImageFilter_blur.jpg')
img1.show()
산출
위의 프로그램을 저장하고 실행하면 다음과 같이 원본 이미지와 표준 PNG 디스플레이 유틸리티를 사용하여 필터링 된 이미지를 보여줍니다.
Original image
Filtered image
그만큼 ImageColor 모듈은 테이블에 배열 된 다른 형식의 색상을 포함하며 CSS3 스타일 색상 지정자에서 RGB 튜플로의 변환기도 포함합니다.
색상 이름
ImageColor 모듈은 다음 문자열 형식을 지원합니다-
#rgb 또는 #rrggbb로 제공되는 16 진수 색상 지정자. 예를 들어 # 00ff00은 순수한 녹색을 나타냅니다.
# 00ff00 hex color, red 값은 0 (0 % red), green 값은 255 (100 % green), RGB의 blue 값은 0 (0 % blue)입니다.
원통형 – 색상 # 00ff00 색상의 좌표 표현 (HSL이라고도 함) : 0.33, 채도 : 1.00 및 00ff00의 밝기 값도 0.50입니다.
이미지 색상 모듈은 X Window 시스템과 대부분의 웹 브라우저에서 지원하는 색상을 기반으로 약 140 개의 표준 색상 이름을 제공합니다. 색상 이름은 대소 문자를 구분하지 않습니다.
ImageColor.getrgb () 메서드
색상 문자열을 RGB 튜플로 변환합니다. 문자열을 구문 분석 할 수없는 경우이 함수에 의해 ValueError 예외가 발생합니다.
통사론
PIL.ImageColor.getrgb(color)
어디,
인수 : color – 색상 문자열
반환 값 : (red, green, blue [, alpha])
예 1
from PIL import ImageColor
# using getrgb
img = ImageColor.getrgb("blue")
print(img)
img1 = ImageColor.getrgb("purple")
print(img1)
산출
(0, 0, 255)
(128, 0, 128)
예 2
#Import required image modules
from PIL import Image,ImageColor
# Create new image & get color RGB tuple.
img = Image.new("RGB", (256, 256), ImageColor.getrgb("#add8e6"))
#Show image
img.show()
산출
ImageColor. getcolor () 메서드
이 메서드는 getrgb ()와 동일하지만 모드가 아닌 경우 RGB 값을 그레이 스케일 값으로 변환합니다. 그래픽 명령은 모양 그리기 및 텍스트 주석 색상 또는 팔레트 이미지를 지원합니다. 문자열을 구문 분석 할 수없는 경우이 함수는 ValueError 예외를 발생시킵니다.
통사론
PIL.ImageColor.getcolor(color, mode)
어디,
인수-색상 문자열
반환 값-(graylevel [, alpha]) 또는 (red, green, blue [, alpha])
예
#Import required image modules
from PIL import Image,ImageColor
# using getrgb
img = ImageColor.getrgb("skyblue")
print(img)
img1 = ImageColor.getrgb("purple")
print(img1)
산출
(135, 206, 235)
(128, 0, 128)
그만큼 ‘ImageDraw’모듈은 Image Object에 대한 간단한 2D 그래픽 지원을 제공합니다. 일반적으로이 모듈을 사용하여 새 이미지를 만들고 기존 이미지에 주석을 달거나 수정하고 웹 사용을 위해 즉석에서 그래픽을 생성합니다.
그래픽 명령은 도형 그리기 및 텍스트 주석을 지원합니다.
이미지는 픽셀의 2 차원 배열 (그림 요소)로 잘 생각할 수 있습니다. 픽셀은 지원되는 색상의 가장 작은 점입니다.
ImageDraw에서 사용하는 2 차원 좌표계의 원점은 upper left corner 이미지의.
우리가 사용하는 베개 색 구성표는 RGB입니다. 색상 RGB 표현 및 지원은 모듈에서 제공합니다.ImageColor.
비트 맵, OpenType 또는 TrueType은 텍스트 주석에 허용되는 글꼴입니다.
대부분의 그리기 명령에는 명령을 적용 할 이미지 영역을 지정하는 경계 상자 매개 변수가 필요할 수 있습니다.
일련의 좌표는 [(x0, y0), (x1, y1),… (xn, yn)]로 나타낼 수 있습니다.
일부 그리기 명령의 경우 각도 값이 필요합니다.
예
다음 파이썬 예제는 주어진 이미지에 선을 그립니다-
#Import required libraries
import sys
from PIL import Image, ImageDraw
#Create Image object
im = Image.open("images/logo.jpg")
#Draw line
draw = ImageDraw.Draw(im)
draw.line((0, 0) + im.size, fill=128)
draw.line((0, im.size[1], im.size[0], 0), fill=128)
#Show image
im.show()
산출
위의 프로그램을 Example.py로 저장하고 실행하면 다음과 같이 이미지에 선을 그리고 표준 PNG 디스플레이 유틸리티를 사용하여 표시합니다.
캔버스
ImageDraw는 이미지의 필로우 드로어 블 표면 (예 : 캔버스)입니다.
ImageDraw.Draw (img)는 Image 매개 변수 img의 드로어 블 캔버스 표현을 반환합니다. 캔버스의 배경은 "img"이미지입니다.
예
다음 파이썬 예제는 주어진 이미지에 텍스트를 그립니다-
#Import required modules from Pillow package
from PIL import Image, ImageDraw, ImageFont
# get an image
base = Image.open('images/boy.jpg').convert('RGBA')
# make a blank image for the text, initialized to transparent text color
txt = Image.new('RGBA', base.size, (255,255,255,0))
# get a font
fnt = ImageFont.truetype('E:/PythonPillow/Fonts/Pacifico.ttf', 40)
# get a drawing context
d = ImageDraw.Draw(txt)
# draw text, half opacity
d.text((14,14), "Tutorials", font=fnt, fill=(255,255,255,128))
# draw text, full opacity
d.text((14,60), "Point", font=fnt, fill=(255,255,255,255))
out = Image.alpha_composite(base, txt)
#Show image
out.show()
산출
'ImageDraw'모듈을 사용하여 도형 그리기
ImageDraw 모듈을 사용하면 작업하려는 이미지로 그리기 개체를 먼저 만든 다음 적용하여 다른 모양을 만들 수 있습니다. 'ImageDraw'모듈을 사용하여 그릴 수있는 일반적인 모양은 다음과 같습니다.
선
다음은 파이썬 베개를 사용하여 선을 그리는 구문입니다.
draw.line(xy, fill=None, width=0)
그만큼 line()메서드는 경계 상자 xy 및 캔버스의 왼쪽 상단에서 오른쪽 하단 모서리까지 선을 그립니다. 선은 색상 채우기를 사용하여 채워집니다. 기본값 없음 및 0은 각각 선택적인 매개 변수 채우기 및 너비에 대한 것입니다.
예
from PIL import Image, ImageDraw
img = Image.new('RGB', (500, 300), (125, 125, 125))
draw = ImageDraw.Draw(img)
draw.line((200, 100, 300, 200), fill=(0, 0, 0), width=10)
img.show()
산출
식
다음은 파이썬 베개를 사용하여 타원을 그리는 구문입니다.
draw.ellipse(xy, fill=None, outline=None)
그만큼 ellipse()메서드는 그릴 때 경계 상자 xy로 둘러싸인 타원을 그립니다. 모양은 색상 채우기와 색상 윤곽선의 둘레를 사용하여 채워집니다. 기본값 없음은 선택 사항 인 채우기 및 너비 매개 변수에 대한 것입니다.
예
from PIL import Image, ImageDraw
img = Image.new('RGB', (500, 300), (125, 125, 125))
draw = ImageDraw.Draw(img)
draw.ellipse((200, 125, 300, 200), fill=(255, 0, 0), outline=(0, 0, 0))
img.show()
산출
직사각형
다음은 파이썬 베개를 사용하여 직사각형을 그리는 구문입니다.
draw.rectangle(xy, fill=None, outline=None)
그만큼 rectangle()메서드는 그릴 때 경계 상자 xy가 지정된 사각형을 그립니다. 모양은 색상 채우기와 색상 윤곽선의 둘레를 사용하여 채워집니다. 기본값 없음은 선택 사항 인 채우기 및 너비 매개 변수에 대한 것입니다.
from PIL import Image, ImageDraw
img = Image.new('RGB', (500, 300), (125, 125, 125))
draw = ImageDraw.Draw(img)
draw.rectangle(
(200, 125, 300, 200),
fill=(255, 0, 0),
outline=(0, 0, 0))
img.show()
산출
다각형
다음은 파이썬 베개를 사용하여 직사각형을 그리는 구문입니다.
draw.polygon(seq, fill=None, outline=None)
그만큼 polygon()메서드는 그리기시 순서대로 좌표 시퀀스 위치를 직선으로 연결하는 다각형을 그립니다. seq의 첫 번째와 마지막 좌표도 직선으로 연결됩니다. 모양은 색상 채우기와 색상 윤곽선의 둘레를 사용하여 채워집니다. 매개 변수 채우기 및 윤곽선은 선택 사항이며 기본값은 없음입니다.
from PIL import Image, ImageDraw
img = Image.new('RGB', (500, 300), (125, 125, 125))
draw = ImageDraw.Draw(img)
draw.polygon(
((200, 200), (300, 100), (250, 50)),
fill=(255, 0, 0),
outline=(0, 0, 0))
img.show()
산출
Python Imaging Library (PIL)에는 이미지 시퀀스 (애니메이션 형식)에 대한 몇 가지 기본 지원이 포함되어 있습니다. FLI / FLC, GIF 및 몇 가지 실험적 형식이 지원되는 시퀀스 형식입니다. TIFF 파일에는 두 개 이상의 프레임도 포함될 수 있습니다.
시퀀스 파일을 열면 PIL은 시퀀스의 첫 번째 프레임을 자동으로로드합니다. 다른 프레임 사이를 이동하려면 seek 및 tell 메서드를 사용할 수 있습니다.
from PIL import Image
img = Image.open('bird.jpg')
#Skip to the second frame
img.seek(1)
try:
while 1:
img.seek(img.tell() + 1)
#do_something to img
except EOFError:
#End of sequence
pass
산출
raise EOFError
EOFError
위에서 볼 수 있듯이 시퀀스가 끝나면 EOFError 예외가 발생합니다.
최신 버전의 라이브러리에있는 대부분의 드라이버는 위의 예에서와 같이 다음 프레임 만 찾을 수 있도록 허용합니다. 파일을 되감 으려면 파일을 다시 열어야 할 수 있습니다.
시퀀스 반복기 클래스
class ImageSequence:
def __init__(self, img):
self.img = img
def __getitem__(self, ix):
try:
if ix:
self.img.seek(ix)
return self.img
except EOFError:
raise IndexError # end of sequence
for frame in ImageSequence(img):
# ...do something to frame...
텍스트의 위치, 텍스트 자체 및 텍스트의 색상을 전달하여 이미지에 텍스트를 쓸 수 있습니다. 이 메소드에 여러 다른 매개 변수를 전달할 수 있습니다.
예
from PIL import Image, ImageDraw
img = Image.open(beach1.jpg')
d1 = ImageDraw.Draw(img)
d1.text((28, 36), "Hello, TutorialsPoint!", fill=(255, 0, 0))
img.show()
img.save("images/image_text.jpg")
입력
산출
위의 프로그램을 Example.py로 저장하고 실행하면 다음과 같이 주어진 텍스트를 추가하고 표준 PNG 디스플레이 유틸리티를 사용하여 표시합니다.
글꼴 선택
이미지에 쓰는 데 사용되는 글꼴을 선택하는 방법에는 여러 가지가 있습니다. 함수의 전체 경로를 전달하여 시스템에서 직접 글꼴을로드하거나 ImageFont를 사용하여 TrueType 글꼴을로드 할 수 있습니다.
예
from PIL import Image, ImageDraw, ImageFont
img = Image.open('images/logo.jpg')
d1 = ImageDraw.Draw(img)
myFont = ImageFont.truetype('E:/PythonPillow/Fonts/FreeMono.ttf', 40)
d1.text((0, 0), "Sample text", font=myFont, fill =(255, 0, 0))
img.show()
img.save("images/image_text.jpg")
산출
이 장에서는 numpy를 사용하여 파이썬 이미징 라이브러리 "베개"를 사용하여 이미지 데이터를 저장하고 조작합니다.
이 장을 진행하기 전에 관리자 모드에서 명령 프롬프트를 열고 다음 명령을 실행하여 numpy를 설치하십시오.
pip install numpy
Note − PIP를 설치하고 업데이트 한 경우에만 작동합니다.
Numpy 배열에서 이미지 만들기
PIL을 사용하여 RGB 이미지를 만들고 jpg 파일로 저장합니다. 다음 예에서 우리는-
150 x 250 픽셀 배열을 만듭니다.
배열의 왼쪽 절반을 주황색으로 채 웁니다.
배열의 오른쪽 절반을 파란색으로 채 웁니다.
from PIL import Image
import numpy as np
arr = np.zeros([150, 250, 3], dtype=np.uint8)
arr[:,:100] = [255, 128, 0]
arr[:,100:] = [0, 0, 255]
img = Image.fromarray(arr)
img.show()
img.save("RGB_image.jpg")
산출
그레이 스케일 이미지 만들기
그레이 스케일 이미지를 만드는 것은 RGB 이미지를 만드는 것과 약간 다릅니다. 2 차원 배열을 사용하여 회색조 이미지를 만들 수 있습니다.
from PIL import Image
import numpy as np
arr = np.zeros([150,300], dtype=np.uint8)
#Set grey value to black or white depending on x position
for x in range(300):
for y in range(150):
if (x % 16) // 8 == (y % 16)//8:
arr[y, x] = 0
else:
arr[y, x] = 255
img = Image.fromarray(arr)
img.show()
img.save('greyscale.jpg')
산출
이미지에서 numpy 배열 만들기
PIL 이미지를 numpy 배열로 또는 그 반대로 변환 할 수 있습니다. 이를 보여주는 작은 프로그램이 아래에 나와 있습니다.
예
#Import required libraries
from PIL import Image
from numpy import array
#Open Image & create image object
img = Image.open('beach1.jpg')
#Show actual image
img.show()
#Convert an image to numpy array
img2arr = array(img)
#Print the array
print(img2arr)
#Convert numpy array back to image
arr2im = Image.fromarray(img2arr)
#Display image
arr2im.show()
#Save the image generated from an array
arr2im.save("array2Image.jpg")
산출
위의 프로그램을 Example.py로 저장하고 실행하면-
원본 이미지를 표시합니다.
검색된 배열을 표시합니다.
배열을 다시 이미지로 변환하고 표시합니다.
show () 메서드를 사용했기 때문에 이미지는 다음과 같이 기본 PNG 표시 유틸리티를 사용하여 표시됩니다.
[[[ 0 101 120]
[ 3 108 127]
[ 1 107 123]
...
...
[[ 38 59 60]
[ 37 58 59]
[ 36 57 58]
...
[ 74 65 60]
[ 59 48 42]
[ 66 53 47]]
[[ 40 61 62]
[ 38 59 60]
[ 37 58 59]
...
[ 75 66 61]
[ 72 61 55]
[ 61 48 42]]
[[ 40 61 62]
[ 34 55 56]
[ 38 59 60]
...
[ 82 73 68]
[ 72 61 55]
[ 63 52 46]]]
Original Image
Image constructed from the array