使用SimpleITK讀取和保存NIfTI/DICOM文件實(shí)例
我就廢話不多說了,大家還是直接看代碼吧~
## using simpleITK to load and save data. import SimpleITK as sitk itk_img = sitk.ReadImage('./nifti.nii.gz') img = sitk.GetArrayFromImage(itk_img) print("img shape:",img.shape) ## save out = sitk.GetImageFromArray(img) # # out.SetSpacing(itk_img.GetSpacing()) # # out.SetOrigin(itk_img.GetOrigin()) sitk.WriteImage(out,'simpleitk_save.nii.gz')
讀取DICOM序列
import sys import SimpleITK as sitk import numpy as np dcm_directory = "./flair_dicom" series_ids = sitk.ImageSeriesReader.GetGDCMSeriesIDs(dcm_directory) print("series ids:",series_ids) if not series_ids: print("ERROR: given directory dose not a DICOM series.") sys.exit(1) series_file_names = sitk.ImageSeriesReader.GetGDCMSeriesFileNames(dcm_directory,series_ids[0]) series_reader = sitk.ImageSeriesReader() series_reader.SetFileNames(series_file_names) image3D = series_reader.Execute() size = image3D.GetSize() print( "Image size:", size[0], size[1], size[2] ) image_array = sitk.GetArrayFromImage(image3D) # SimpleITK讀取的圖像數(shù)據(jù)的坐標(biāo)順序?yàn)閦yx,即從多少張切片到單張切片的寬和高; # 而據(jù)SimpleITK Image獲取的origin和spacing的坐標(biāo)順序則是xyz origin = image3D.GetOrigin() spacing = image3D.GetSpacing() print("origin:",origin," spacing:",spacing)
讀取DICOM單個文件
import SimpleITK as sitk import numpy as np image = sitk.ReadImage(slice_path) image_array = sitk.GetArrayFromImage(image) # z, y, x
補(bǔ)充知識:itk 讀取圖像,兩種格式之間轉(zhuǎn)換
我就廢話不多說了,大家還是直接看代碼吧~
/******************************************************* 控制臺運(yùn)行程序 輸入: 程序名稱 讀取圖像文件名 保存圖像文件名 輸出: 保存另一種類型的圖像 功能: 圖像在jpeg和bmp兩種格式之間互換 ********************************************************/ #include "itkImageFileReader.h" #include "itkImageFileWriter.h" #include "itkImageIOFactory.h" #include "itkBMPImageIOFactory.h" #include "itkJPEGImageIOFactory.h" #include <iostream> int main(int argc , char *argv[]) { if (argc < 3) { std::cerr << "Usage: " << std::endl; std::cerr << argv[0] << " inputImageFile outputImageFile " << std::endl; return EXIT_FAILURE; } itk::BMPImageIOFactory::RegisterOneFactory(); itk::JPEGImageIOFactory::RegisterOneFactory(); typedef itk::Image< unsigned char, 2 > ImageType; typedef itk::ImageFileReader< ImageType > ReaderType; typedef itk::ImageFileWriter< ImageType > WriterType; ReaderType::Pointer reader = ReaderType::New(); WriterType::Pointer writer = WriterType::New(); const char * inputFilename = argv[1]; const char * outputFilename = argv[2]; reader->SetFileName( inputFilename ); writer->SetFileName( outputFilename ); writer->SetInput( reader->GetOutput() ); try { writer->Update(); } catch( itk::ExceptionObject & err ) { std::cerr << "ExceptionObject caught !" << std::endl; std::cerr << err << std::endl; return EXIT_FAILURE; } system("pause"); return 0; }
以上這篇使用SimpleITK讀取和保存NIfTI/DICOM文件實(shí)例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python實(shí)現(xiàn)動態(tài)生成系統(tǒng)數(shù)據(jù)庫設(shè)計到Word文檔
這篇文章主要為大家詳細(xì)介紹了如何利用Python實(shí)現(xiàn)填寫相關(guān)數(shù)據(jù)庫信息后,生成系統(tǒng)數(shù)據(jù)庫設(shè)計到word文檔,文中示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-06-06python進(jìn)階TensorFlow神經(jīng)網(wǎng)絡(luò)擬合線性及非線性函數(shù)
這篇文章是python進(jìn)階學(xué)習(xí)主要介紹了TensorFlow神經(jīng)網(wǎng)絡(luò)擬合線性及非線性函數(shù)原理及示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10django在開發(fā)中取消外鍵約束的實(shí)現(xiàn)
這篇文章主要介紹了django在開發(fā)中取消外鍵約束的實(shí)現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05Python批量刪除只保留最近幾天table的代碼實(shí)例
今天小編就為大家分享一篇關(guān)于Python批量刪除只保留最近幾天table的代碼實(shí)例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-04-04Python實(shí)現(xiàn)計算對象的內(nèi)存大小示例
這篇文章主要介紹了Python實(shí)現(xiàn)計算對象的內(nèi)存大小,結(jié)合實(shí)例形式分析了Python使用sys.getsizeof與遞歸算法計算對象占用內(nèi)存的相關(guān)操作技巧,需要的朋友可以參考下2019-07-07基于python制作簡易版學(xué)生信息管理系統(tǒng)
這篇文章主要介紹了基于python制作簡易版學(xué)生信息管理系統(tǒng),文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)python的小伙伴們有很好地幫助,需要的朋友可以參考下2021-04-04Python實(shí)現(xiàn)查找匹配項(xiàng)作處理后再替換回去的方法
這篇文章主要介紹了Python實(shí)現(xiàn)查找匹配項(xiàng)作處理后再替換回去的方法,涉及Python字符串查找、轉(zhuǎn)換、輸出等相關(guān)操作技巧,需要的朋友可以參考下2017-06-06