.dcm格式文件软件读取及python处理详解


Posted in Python onJanuary 16, 2020

要处理一些.DCM格式的焊接缺陷图像,需要读取和显示.dcm格式的图像。通过搜集资料收集到一些医学影像,并通过pydicom模块查看.dcm格式文件。

若要查看dcm格式文件,可下Echo viewer 进行查看。

若用过pycharm进行处理,可选用如下的代码:

# -*-coding:utf-8-*-
import cv2
import numpy
import dicom
from matplotlib import pyplot as plt

dcm = dicom.read_file("dcm")
dcm.image = dcm.pixel_array * dcm.RescaleSlope + dcm.RescaleIntercept

slices = []
slices.append(dcm)
img = slices[int(len(slices) / 2)].image.copy()
ret, img = cv2.threshold(img, 90, 3071, cv2.THRESH_BINARY)
img = numpy.uint8(img)

im2, contours, _ = cv2.findContours(img, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
mask = numpy.zeros(img.shape, numpy.uint8)
for contour in contours:
  cv2.fillPoly(mask, [contour], 255)
img[(mask > 0)] = 255

kernel = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (2, 2))
img = cv2.morphologyEx(img, cv2.MORPH_OPEN, kernel)

img2 = slices[int(len(slices) / 2)].image.copy()
img2[(img == 0)] = -2000

plt.figure(figsize=(12, 12))
plt.subplot(131)
plt.imshow(slices[int(len(slices) / 2)].image, 'gray')
plt.title('Original')
plt.subplot(132)
plt.imshow(img, 'gray')
plt.title('Mask')
plt.subplot(133)
plt.imshow(img2, 'gray')
plt.title('Result')
plt.show()

也可用如下代码:

import pydicom
import os
import numpy
from matplotlib import pyplot, cm
# 用lstFilesDCM作为存放DICOM files的列表
PathDicom = "dicom/2" #与python文件同一个目录下的文件夹
lstFilesDCM = []
for dirName,subdirList,fileList in os.walk(PathDicom):
  for filename in fileList:
    if ".dcm" in filename.lower(): #判断文件是否为dicom文件
      print(filename)
      lstFilesDCM.append(os.path.join(dirName,filename)) # 加入到列表中
## 将第一张图片作为参考图
RefDs = pydicom.read_file(lstFilesDCM[0])  #读取第一张dicom图片
# 建立三维数组
ConstPixelDims = (int(RefDs.Rows),int(RefDs.Columns),len(lstFilesDCM)) # 得到spacing值 (mm为单位)
ConstPixelSpacing = (float(RefDs.PixelSpacing[0]), float(RefDs.PixelSpacing[1]), float(RefDs.SliceThickness))
# 三维数据
x = numpy.arange(0.0, (ConstPixelDims[0]+1)*ConstPixelSpacing[0], ConstPixelSpacing[0]) # 0到(第一个维数加一*像素间的间隔),步长为constpixelSpacing
y = numpy.arange(0.0, (ConstPixelDims[1]+1)*ConstPixelSpacing[1], ConstPixelSpacing[1]) #
z = numpy.arange(0.0, (ConstPixelDims[2]+1)*ConstPixelSpacing[2], ConstPixelSpacing[2]) #
ArrayDicom = numpy.zeros(ConstPixelDims, dtype=RefDs.pixel_array.dtype)
for filenameDCM in lstFilesDCM:
  ds = pydicom.read_file(filenameDCM)
  ArrayDicom[:, :, lstFilesDCM.index(filenameDCM)] = ds.pixel_array # 轴状面显示
  pyplot.figure(dpi=300)
  pyplot.axes().set_aspect('equal', 'datalim')
  pyplot.set_cmap(pyplot.gray())
  pyplot.pcolormesh(x, y, numpy.flipud(ArrayDicom[:, :, 2])) # 第三个维度表示现在展示的是第几层
  pyplot.show()

这两个代码都是可以进行读取的。但是不知道为什么在焊接检测中的dcm图像却无法进行读取。

以上这篇.dcm格式文件软件读取及python处理详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python Web框架Flask下网站开发入门实例
Feb 08 Python
进一步理解Python中的函数编程
Apr 13 Python
python实现中文输出的两种方法
May 09 Python
使用tensorflow实现AlexNet
Nov 20 Python
Python编程中flask的简介与简单使用
Dec 28 Python
利用python实现在微信群刷屏的方法
Feb 21 Python
基于python-pptx库中文文档及使用详解
Feb 14 Python
python json 递归打印所有json子节点信息的例子
Feb 27 Python
Python HTTP下载文件并显示下载进度条功能的实现
Apr 02 Python
python中元组的用法整理
Jun 15 Python
scrapy与selenium结合爬取数据(爬取动态网站)的示例代码
Sep 28 Python
利用Python实现模拟登录知乎
May 25 Python
用python解压分析jar包实例
Jan 16 #Python
Python3 实现爬取网站下所有URL方式
Jan 16 #Python
python3爬取torrent种子链接实例
Jan 16 #Python
Python 实现自动获取种子磁力链接方式
Jan 16 #Python
关于初始种子自动选取的区域生长实例(python+opencv)
Jan 16 #Python
Python简单实现区域生长方式
Jan 16 #Python
python3.8与pyinstaller冲突问题的快速解决方法
Jan 16 #Python
You might like
PHP生成网页快照 不用COM不用扩展.
2010/02/11 PHP
PHP register_shutdown_function函数的深入解析
2013/06/03 PHP
PHP跳转页面的几种实现方法详解
2013/06/08 PHP
详解thinkphp5+swoole实现异步邮件群发(SMTP方式)
2017/10/13 PHP
PHP设计模式(九)外观模式Facade实例详解【结构型】
2020/05/02 PHP
Microsoft Ajax Minifier 压缩javascript的方法
2010/03/05 Javascript
页面js遇到乱码问题的解决方法是和无法转码的情况
2014/04/30 Javascript
js实现select跳转功能代码
2014/10/22 Javascript
JavaScript中String.prototype用法实例
2015/05/20 Javascript
javascript中日期函数new Date()的浏览器兼容性问题
2015/09/05 Javascript
动态更新highcharts数据的实现方法
2016/05/28 Javascript
关于JS中二维数组的声明方法
2016/09/24 Javascript
微信小程序 picker-view 组件详解及简单实例
2017/01/10 Javascript
node.js中EJS 模板快速入门教程
2017/05/08 Javascript
angular动态表单制作
2018/02/23 Javascript
[01:06:42]VP vs NewBee Supermajor 胜者组 BO3 第二场 6.5
2018/06/06 DOTA
[01:11:02]Secret vs Newbee 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python安装使用命令行交互模块pexpect的基础教程
2016/05/12 Python
Python如何读取MySQL数据库表数据
2017/03/11 Python
Php多进程实现代码
2018/05/07 Python
Python 删除整个文本中的空格,并实现按行显示
2018/07/24 Python
pytorch 数据集图片显示方法
2018/07/26 Python
对python调用RPC接口的实例详解
2019/01/03 Python
python实现多进程通信实例分析
2019/09/01 Python
关于numpy中eye和identity的区别详解
2019/11/29 Python
python带参数打包exe及调用方式
2019/12/21 Python
python 解决flask 图片在线浏览或者直接下载的问题
2020/01/09 Python
PyQt5 界面显示无响应的实现
2020/03/26 Python
使用Dajngo 通过代码添加xadmin用户和权限(组)
2020/07/03 Python
日本网路线上商品代购服务:转送JAPAN
2016/08/05 全球购物
数学系个人求职信范文
2014/01/30 职场文书
幼儿园教学管理制度
2014/02/04 职场文书
酒店员工培训方案
2014/06/02 职场文书
物理教育专业求职信
2014/06/25 职场文书
长城导游词
2015/01/30 职场文书
教师节慰问信
2015/02/15 职场文书