OSError: [Errno 24] Terlalu banyak file yang terbuka menggunakan Nibabel

Saya memiliki program python3.6, menggunakan paket nibabel untuk menganalisis gambar medis dalam format NIFTI.

import glob
import nibabel as nib
health = [nib.load(pt) for pt in glob.glob(healthdir+'*.nii')] # len = 200
health_data = [h.get_data() for h in health]

Itu terjadi OSError: [Errno 24] Too many open files di baris terakhir. Saya menggunakan kode berikut dan menemukan bahwa terjadi kesalahan pada elemen terakhir.

health_data = []
for i in range(len(health)):
    try:
        health_data.append(health[i].get_data())
    except:
        print(i) # 199

Saya telah mencoba mencari topik relatif seperti Nibabel: IOError: [Errno 24 ] Terlalu banyak file yang terbuka:. Namun, hal tersebut tidak menyelesaikan masalah. Selain itu, saya memilih untuk tidak menggunakan ulimit. Terima kasih!


person djfire    schedule 04.03.2018    source sumber
comment
Hai @djfire, apakah Anda pernah berhasil mengatasi ini?   -  person JDoe2    schedule 18.12.2020


Jawaban (2)


Tidak familiar dengan Nibabel tapi Coba with

    health_data = []
    for filepath in glob.glob(healthdir+'*.nii'):
       with nib.load(filepath) as health:
           health_data.append(health.get_data())

**TIDAK DIUJI

person webbyfox    schedule 04.03.2018

Anda mungkin perlu menghapus objek tersebut setelah menggunakannya.

def show_origin_image(name,s=100,max_limit=None, min_limit=None):
    origin = name
    file_name_list = [each for each in os.listdir(origin) if not each.startswith('.')]
    file_name_list = file_name_list[min_limit:max_limit]
    dimension = 2
    width_num = 6
    height_num = math.ceil(len(file_name_list) / width_num)
    plt.figure(figsize=(15, height_num * 2.8))
    data_list = []
    for n,each in enumerate(file_name_list, 1):
        agent = nib.load(os.path.join(origin, each), keep_file_open=False)
        three_d_data = np.asarray(agent.dataobj)
        size = three_d_data.shape
        image = np.take(three_d_data, s, dimension)
        plt.subplot(height_num, width_num, n)
        plt.imshow(image, 'gray')
        plt.axis('off')
        data_list.append(three_d_data)
        # add delete operation!
        del agent
    return data_list
person Weiziyoung    schedule 12.07.2019