如何在没有CT的情况下使用pydicom显示图像?

时间:2018-04-23 04:45:27

标签: python python-3.x image pydicom

如何在没有CT(轮廓)的情况下使用pydicom显示图像?

目前它显示图像,但它包括轮廓,我想显示根图像,如果可以,没有根图像的轮廓

这是我的参考代码,但我在控制台中测试了搜索

import matplotlib.pyplot as plt
import pydicom
#from pydicom.data import get_testdata_files

PathDicom = "./Dicoms/"
lstFilesDCM = []  # create an empty list
Pattient = []  # create an empty list
for dirName, subdirList, fileList in os.walk(PathDicom):
    for filename in fileList:
        if ".dcm" in filename.lower():  # check whether the file's DICOM
            lstFilesDCM.append(os.path.join(dirName,filename))
            dataset = pydicom.dcmread(os.path.join(dirName,filename))
            print(__doc__)
#            filename = get_testdata_files(os.path.join(dirName,filename))[0]
#            dataset = pydicom.dcmread(filename)

            # Normal mode:
            print()
            print("Filename.........:", filename)
            print("Storage type.....:", dataset.SOPClassUID)
            print()

            pat_name = dataset.PatientName
            display_name = pat_name.family_name + ", " + pat_name.given_name
            print("Patient's name...:", display_name)
            print("Patient id.......:", dataset.PatientID)
            print("Study id.......:", dataset.StudyID)
            print("Modality.........:", dataset.Modality)
            print("Study Date.......:", dataset.StudyDate)
            print("Contour..........:", dataset.dir("contour"))
            #espesor de corte
            print("Slice Thickness..:", dataset.SliceThickness)

            if 'PixelData' in dataset:
                rows = int(dataset.Rows)
                cols = int(dataset.Columns)
                print("Image size.......: {rows:d} x {cols:d}, {size:d} bytes".format(
                    rows=rows, cols=cols, size=len(dataset.PixelData)))
                if 'PixelSpacing' in dataset:
                    print("Pixel spacing....:", dataset.PixelSpacing)

            # use .get() if not sure the item exists, and want a default value if missing
            print("Slice location...:", dataset.get('SliceLocation', "(missing)"))
            #plot the image with contouring
            plt.imshow(dataset.pixel_array, cmap=plt.cm.bone)

1 个答案:

答案 0 :(得分:0)

我建议您查看dicompyler以获取如何显示图像和轮廓的示例。它使用wxPython进行显示,但如果需要,可以将概念转换为其他图形库。或者您可以根据需要为dicompyler添加自定义插件。