使用python批量读取mhd格式和raw格式医学图像

2023-11-05 16:20

本文主要是介绍使用python批量读取mhd格式和raw格式医学图像,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我的数据存放大致如下所示
在这里插入图片描述
E:/105casesMask_Seg是总的数据文件夹,Cxxx文件夹存放的是每个病人mhd文件,文件名字就相当于后面的patient_name

#导入需要的包
import os
from PIL import Image
import SimpleITK as sitk
import matplotlib.pyplot as plt
from natsort import natsorted
from tqdm import tqdm#获取文件内的的子文件夹名称
def get_file_name(filename):for root, dirs, files in os.walk(filename):array = dirsif array:return array
#创建空目录
def make_dir(save_path):if not os.path.isdir(save_path):os.makedirs(save_path)#将一个病人的所有图片整合在一张图打印出来
def plot_ct_scan(scan, num_column=4, jump=1):num_slices = len(scan)num_row = (num_slices//jump + num_column - 1) // num_columnf, plots = plt.subplots(num_row, num_column, figsize=(num_column*5, num_row*5))for i in range(0, num_row*num_column):plot = plots[i % num_column] if num_row == 1 else plots[i // num_column, i % num_column]        plot.axis('off')if i < num_slices//jump:plot.imshow(scan[i*jump], cmap=plt.cm.bone) #读取图片并保存
def save_img(data_path,save_path):root = os.path.join(os.getcwd(),data_path)paths = os.listdir(root)print(paths)for path in paths:if path.find('mhd')>=0:data =sitk.ReadImage(os.path.join(root,path))   #读取mhd文件#print(data)spacing = data.GetSpacing()scan = sitk.GetArrayFromImage(data)print('scan.shape',scan.shape) #图像大小print('spacing: ', spacing)   #间隔print('# slice: ', len(scan)) #切片数量#plot_ct_scan(scan)make_dir(save_path)for i in range(scan.shape[0]):im = Image.fromarray(scan[i,:,:])   #这里就是提取的图片数据  im.save(save_path+'/'+str(i)+'.png')  #保存图片if __name__ == '__main__':data_dir = 'E:/105casesMask_Seg/'   #mhd数据存放位置result_dir = 'E:/labels/'   #读取的图片存放位置patients_name = get_file_name( data_dir )patients_name = natsorted(patients_name )#print(data_dir)for patient_name in tqdm(patients_name):   #分别保存每个病人数据data_path = data_dir  + patient_namesave_path = result_dir + patient_namemake_dir(save_path)save_img(data_path,save_path)

这篇关于使用python批量读取mhd格式和raw格式医学图像的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/351021

相关文章

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

Ubuntu如何升级Python版本

《Ubuntu如何升级Python版本》Ubuntu22.04Docker中,安装Python3.11后,使用update-alternatives设置为默认版本,最后用python3-V验证... 目China编程录问题描述前提环境解决方法总结问题描述Ubuntu22.04系统自带python3.10,想升级

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum