当前位置:   article > 正文

如何将nii图像文件转换为png图像,亲测有效!!!_nii转png

nii转png

本文介绍一种批量转换nii文件到png图像的方法,亲测可用!!!

1、说明:

##以下图为例,进行转换
在这里插入图片描述转换后,针对每个文件生成对应得文件夹,文件夹下面有一个‘z’文件夹(沿着z轴划分的切片),该文件夹下面是所有切片后的png或者jpg图像。
转换后效果如下:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

2、下面进行详细的代码展示:

###只需要进行简单的路径修改即可实现批量转换!!!
代码如下(示例):

import matplotlib

matplotlib.use('TkAgg')
import nibabel as nib
import numpy as np

import os
import imageio


# ---------------------------------------------#
# nii_path : nii文件的路径
# img_save_path : 切片的保存路径
# axis : 说明是沿着哪个方向切片的
# ---------------------------------------------
def nii_to_png(nii_path, img_save_path, axis):
    # 若保存路径不存在,则创建
    if not os.path.exists(img_save_path):
        os.makedirs(img_save_path)

    nii = nib.load(nii_path)
    nii_fdata = nii.get_fdata()
    nii_fdata = np.rot90(nii_fdata)

    # 以切片的轴向作为保存png的子文件夹名
    foldername = axis
    png_save_path = os.path.join(img_save_path, foldername)
    if not os.path.exists(png_save_path):
        os.mkdir(png_save_path)

    flag = 100
    if axis == 'x':
        (axis, y, z) = nii.shape
        flag = 0
    elif axis == 'y':
        (x, axis, z) = nii.shape
        flag = 1
    elif axis == 'z':
        (x, y, axis) = nii.shape
        flag = 2
    else:
        print("wrong axis")

    for i in range(axis):
        if flag == 0:
            slice = nii_fdata[i, :, :]
        elif flag == 1:
            slice = nii_fdata[:, i, :]
        elif flag == 2:
            slice = nii_fdata[:, :, i]
        # 以数字1,2,3...为png图片命名
        imageio.imwrite(os.path.join(png_save_path, '{}.png'.format(i)), slice)
def all_nii_to_png(all_nii_path,all_image_save_path, axis):
    all_nii_path_list = os.listdir(all_nii_path)
    for i in range(len(all_nii_path_list)):
        nii_to_png(os.path.join(all_nii_path,all_nii_path_list[i]),os.path.join(all_image_save_path, all_nii_path_list[i]), axis)
        print("第{}个nii文件转换完成!".format(i))

if __name__ == "__main__":
    all_nii_path = r'E:\all_dataset\covid-19-ct-seg\Lung_Mask'
    all_image_save_path = r'E:\all_dataset\covid-19-ct-seg\Lung_Mask_processed'
    all_nii_to_png(all_nii_path, all_image_save_path, 'z')

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/blog/article/detail/83798
推荐阅读
相关标签
  

闽ICP备14008679号