python实现批量nii文件转换为png图像


Posted in Python onJuly 18, 2019

之前介绍过单个nii文件转换成png图像:

这里介绍将多个nii文件(保存在一个文件夹下)转换成png图像。且图像单个文件夹的名称与nii名字相同。

import numpy as np
import os    #遍历文件夹
import nibabel as nib #nii格式一般都会用到这个包
import imageio   #转换成图像
 
def nii_to_image(niifile):
 filenames = os.listdir(filepath) #读取nii文件夹
 slice_trans = []
 
 for f in filenames:
  #开始读取nii文件
  img_path = os.path.join(filepath, f)
  img = nib.load(img_path)    #读取nii
  img_fdata = img.get_fdata()
  fname = f.replace('.nii','')   #去掉nii的后缀名
  img_f_path = os.path.join(imgfile, fname)
  #创建nii对应的图像的文件夹
  if not os.path.exists(img_f_path):
   os.mkdir(img_f_path)    #新建文件夹
 
  #开始转换为图像
  (x,y,z) = img.shape
  for i in range(z):      #z是图像的序列
   silce = img_fdata[i, :, :]   #选择哪个方向的切片都可以
   imageio.imwrite(os.path.join(img_f_path,'{}.png'.format(i)), silce)
            #保存图像
 
if __name__ == '__main__':
 filepath = 'nii的文件夹'
 imgfile = 'image的文件夹'
 nii_to_image(filepath)

代码是我自己写的,用于处理ADNI的nii格式完全有效。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python多线程编程中的join函数使用心得
Sep 02 Python
Python的标准模块包json详解
Mar 13 Python
利用aardio给python编写图形界面
Aug 21 Python
Python实现购物车购物小程序
Apr 18 Python
Python实现的根据文件名查找数据文件功能示例
May 02 Python
详解Python3除法之真除法、截断除法和下取整对比
May 23 Python
pytorch获取vgg16-feature层输出的例子
Aug 20 Python
Python可变对象与不可变对象原理解析
Feb 25 Python
Selenium自动化测试工具使用方法汇总
Jun 12 Python
python 实现两个npy档案合并
Jul 01 Python
用基于python的appium爬取b站直播消费记录
Apr 17 Python
告别网页搜索!教你用python实现一款属于自己的翻译词典软件
Jun 03 Python
django 捕获异常和日志系统过程详解
Jul 18 #Python
Django实现发送邮件功能
Jul 18 #Python
使用django的ORM框架按月统计近一年内的数据方法
Jul 18 #Python
Django框架之登录后自定义跳转页面的实现方法
Jul 18 #Python
django页面跳转问题及注意事项
Jul 18 #Python
django框架模板语言使用方法详解
Jul 18 #Python
Django中间件基础用法详解
Jul 18 #Python
You might like
具有时效性的php加密解密函数代码
2013/06/19 PHP
又一个PHP实现的冒泡排序算法分享
2014/08/21 PHP
PHP使用ob_start生成html页面的方法
2014/11/07 PHP
一个很酷的拖动层的js类,兼容IE及Firefox
2009/06/23 Javascript
基于jQuery捕获超链接事件进行局部刷新代码
2012/05/10 Javascript
jQuery+css实现图片滚动效果(附源码)
2013/03/18 Javascript
更高效的使用JQuery 这里总结了8个小技巧
2016/04/13 Javascript
JS针对浏览器窗口关闭事件的监听方法集锦
2016/06/24 Javascript
Bootstrap编写一个在当前网页弹出可关闭的对话框 非弹窗
2016/06/30 Javascript
jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法
2017/03/08 Javascript
nodejs实现邮件发送服务实例分享
2017/03/29 NodeJs
jQuery实现仿京东防抖动菜单效果示例
2018/07/06 jQuery
laydate时间日历插件使用方法详解
2018/11/14 Javascript
详解在Javascript中进行面向切面编程
2019/04/28 Javascript
解决vue+router路由跳转不起作用的一项原因
2020/07/19 Javascript
[01:46]2018完美盛典章节片——坚守
2018/12/17 DOTA
举例讲解Python中is和id的用法
2015/04/03 Python
Python实现批量读取word中表格信息的方法
2015/07/30 Python
基于Python实现用户管理系统
2019/02/26 Python
pytorch绘制并显示loss曲线和acc曲线,LeNet5识别图像准确率
2020/01/02 Python
Tensorflow设置显存自适应,显存比例的操作
2020/02/03 Python
Python super()函数使用及多重继承
2020/05/06 Python
Python如何输出整数
2020/06/07 Python
matplotlib.pyplot.matshow 矩阵可视化实例
2020/06/16 Python
CSS3动画效果回调处理详解
2014/12/10 HTML / CSS
HTML5 Web Workers之网站也能多线程的实现
2013/04/24 HTML / CSS
HTML5 Canvas中使用用路径描画圆弧
2015/01/01 HTML / CSS
倩碧澳大利亚官网:Clinique澳大利亚
2019/07/22 全球购物
在网络中有两台主机A和B,并通过路由器和其他交换设备连接起来,已经确认物理连接正确无误,怎么来测试这两台机器是否连通?如果不通,怎么来判断故障点?怎么排
2014/01/13 面试题
非功能性需求都包括哪些方面
2013/10/29 面试题
校园公益广告语
2014/03/13 职场文书
项目采购员岗位职责
2014/04/15 职场文书
追讨欠款律师函
2015/06/24 职场文书
重阳节主题班会
2015/08/17 职场文书
Vue实现动态查询规则生成组件
2021/05/27 Vue.js
P站美图推荐——变身女主角特辑
2022/03/20 日漫