医学图像处理png转nii

from PIL import Image
import numpy as np
import SimpleITK as sitk
import os
png_path='Train_Sets/MR/1/T2SPIR/Ground'
nii_path='CHAOS/'
# nii_file = sitk.GetImageFromArray(anno_mat)
# # anno_mat 为一个矩阵,其维度必须是按照(样本数*高度*宽度)排列 否则,保存的结果错误
# sitk.WriteImage(nii_file, nii_path)  # nii_path 为保存路径

empt_mat = []
files=os.listdir(png_path)
files.sort(key=lambda x:int(x[9:-4]))
for i in files:
    if i!='.DS_Store':
        print(i)

        img1 = Image.open(os.path.join(png_path,i))
        img2 = np.array(img1)
        # print(img2)
    # 这里取png图片的前三个通道,去除第四个透明通道 方便后续的nii文件的处理
        empt_mat.append(img2)
        print(empt_mat)
        print(len(empt_mat))
        emp = np.array(empt_mat)
        # print(emp)
        nii_file = sitk.GetImageFromArray(emp)
        # print(111)
        # print(nii_file)
    # 此处的emp的格式为样本数*高度*宽度*通道数
    # 不要颠倒这些维度的顺序,否则文件保存错误
nii_path=(nii_path+'111_1'+'.nii.gz')
sitk.WriteImage(nii_file, nii_path)  # nii_path 为保存路径
  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值