py将dicm格式图片转为jpg格式
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                py将dicm格式图片转为jpg格式
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.                        
                                
                            
                            
                            import pydicom # 用來解析dicom格式圖像的像素值
import numpy as np
import cv2 # 用于保存圖片
import os# 定義dicom to jpg轉(zhuǎn)換函數(shù)
def convert_from_dicom_to_jpg(img, low_window, high_window, save_path):""":param img: dicom圖像的像素值信息:param low_window: dicom圖像像素值的最低值:param high_window: dicom圖像像素值的最高值:param save_path: 新生成的jpg圖片的保存路徑:return:"""lungwin = np.array([low_window * 1., high_window * 1.]) # 將pydicom解析的像素值轉(zhuǎn)換為arraynewimg = (img - lungwin[0]) / (lungwin[1] - lungwin[0]) # 將像素值歸一化0-1newimg = (newimg * 255).astype('uint8') # 再轉(zhuǎn)換至0-255,且將編碼方式由原來的unit16轉(zhuǎn)換為unit8# 用cv2寫入圖像指令,保存jpg即可cv2.imwrite(save_path, newimg, [int(cv2.IMWRITE_JPEG_QUALITY), 100])path = 'D:/dcm' # dicom文件夾路徑
filename = os.listdir(path) # 打開文件夾中的圖像的文件名,作為列表返回
# print(filename) # 可查看一下文件夾下有哪些文件# 開始遍歷文件夾下的每張dicom圖像
for i in filename:document = os.path.join(path, i)outputpath = 'D:/jpg' # 保存jpg圖像的路徑countfullname = i + '.jpg' # 后綴.jpgoutput_jpg_path = os.path.join(outputpath, countfullname) # 設(shè)置保存每張圖片的路徑ds = pydicom.dcmread(document,force=True) # 解析一張dicom圖片img_array = ds.pixel_array # 將像素值信息提取# ds_array = sitk.ReadImage(document)# img_array = sitk.GetArrayFromImage(ds_array)# shape = img_array.shape  # name.shape# img_array = np.reshape(img_array, (shape[1], shape[2]))high = np.max(img_array) # 找到最大的low = np.min(img_array)# 找到最小的# 調(diào)用函數(shù),開始轉(zhuǎn)換convert_from_dicom_to_jpg(img_array, low, high, output_jpg_path)print(i) 
                        
                        
                        ?
總結(jié)
以上是生活随笔為你收集整理的py将dicm格式图片转为jpg格式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 云服务器带外管理-从IPMI到RedFi
- 下一篇: HTTP消息推送原理
