개발하자

주피터 노트북을 사용하여 그리드에 여러 png을 표시하는 방법

Cuire 2022. 11. 29. 03:21
반응형

주피터 노트북을 사용하여 그리드에 여러 png을 표시하는 방법

나는 주피터 노트북과 같은 폴더에 있는 파일 이름 목록을 가지고 있다.

fnames =

노트북 출력 셀 내부의 그리드에 다음과 같은 이미지를 표시하려고 합니다.

  • 행수
  • 열 수
  • 표시할 이미지 딤(픽셀 단위)(각 이미지에 대해 딤 표시)



다음을 수행하십시오.

import os
import numpy as np
import matplotlib.pyplot as plt

directory = "./Images/"
images = os.listdir(directory)

fig = plt.figure(figsize=(10, 10))
columns = 2
rows = np.ceil(len(images))

for x, i in enumerate(images):
    path =  os.path.join("./Images/",i)
    img = plt.imread(path)
    fig.add_subplot(rows, columns, x+1)
    plt.imshow(img)
plt.show()



:

import os
import ipywidgets as widgets
from IPython.display import display

# Define a useful function
def get_image(f_path):
    '''
    Returns the image from a path
    '''
    img_labs = ['jpg','png']
    if any(x in img_labs for x in f_path.split('.')):
        file = os.path.join(folder,f_path)
        image = open(file,'rb').read()
        return image

# Do the actual work here
folder = 'Some Path to a Folder of Images'
files  = os.listdir(folder)
images = [get_image(x) for x in files]
children = [widgets.Image(value = img) for img in images if str(type(img)) != '<class \'NoneType\'>']
labels = ['{}'.format(i) for i in range(len(children))]

# Customize your layout here:
box_layout = widgets.Layout(
    display='flex',
    flex_flow='column',
    align_items='stretch',
    border='solid',
    width='50%')

# Create the widget
tab = widgets.Tab()
tab.children = children

# Label em'!
for i in range(len(children)):
    tab.set_title(i,labels[i])

display(tab)

자세한 내용은 을 참조하십시오.


반응형