pydicom提取DICOM胸片图像

提取效果图

提取出的图片

下载pydicom

pip install pydicom
# 如果提示缺乏pylibjpeg等组件请执行代码安装扩展
pip install pylibjpeg
pip install pylibjpeg-libjpeg
pip install gdcm

Code

import pydicom
import numpy as np
# 使用PIL.Image提取出来的图片会很暗
from matplotlib import pyplot as plt
import os
# dicom文件路径
dicom_path = './1.dicom'
# png图片提取路径
png_path = './png'

if __name__ == "__main__":
	# 读取dicom文件
    ds = pydicom.dcmread(dicom_path)
    # 当数据维度大于2,证明有多张图片,当前文件是单通道的图
    if len(ds.pixel_array.shape) > 2:
    	# 循环提取图片
        for index in range(int(ds.pixel_array.shape[0])):
        	# 根据dicom文件的BitAllocation显示16,代表是16位图像
            img = np.asarray(ds.pixel_array[index], dtype='uint16')
            img_upload_path = os.path.join(png_path, str(index) + ".png")
            # cmap参数是重点,选择plt.cm.bone,胸片显示才会正常
            plt.imsave(img_upload_path, img, cmap=plt.cm.bone)
    else:
    	# 单图
        img = np.asarray(ds.pixel_array, dtype='uint16')
        img_upload_path = os.path.join(png_path, "0.png")
        plt.imsave(img_upload_path, img, cmap=plt.cm.bone)
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Alex-Leung

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值