nii格式转换为png,指定矢状图 冠状位 水平位

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]
        # 以0001,0002,0003...为png图片命名
        imageio.imwrite(os.path.join(png_save_path, '{:04d}.png'.format(i+1)), 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:\24_5data\label_nii'
    all_image_save_path = r'E:\24_5data\label_png'
    all_nii_to_png(all_nii_path, all_image_save_path, 'z')      # x y z

# nii_path : nii文件的路径
# img_save_path : 切片的保存路径
# axis : 说明是沿着哪个方向切片的
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值