Introduction to pydicom¶
Brief overview of pydicom.
pydicom is a pure Python package for working with DICOM files such as medical images, reports, and radiotherapy objects.
pydicom makes it easy to read these complex files into natural pythonic structures for easy manipulation. Modified datasets can be written again to DICOM format files.
Here is a simple example of using pydicom in an interactive session, to read a radiotherapy plan file, change the patient setup from head-first-supine to head-first-prone, and save to a new file:
>>> import pydicom >>> from pydicom.data import get_testdata_file >>> filename = get_testdata_file("rtplan.dcm") >>> ds = pydicom.dcmread(filename) # plan dataset >>> ds.PatientName 'Last^First^mid^pre' >>> ds.dir("setup") # get a list of tags with "setup" somewhere in the name ['PatientSetupSequence'] >>> ds.PatientSetupSequence (0018, 5100) Patient Position CS: 'HFS' (300a, 0182) Patient Setup Number IS: '1' (300a, 01b2) Setup Technique Description ST: '' >>> ds.PatientSetupSequence.PatientPosition = "HFP" >>> ds.save_as("rtplan2.dcm")
pydicom is not a DICOM server (see pynetdicom instead), and is not primarily about viewing images. It is designed to let you manipulate data elements in DICOM files with Python code.
pydicom is easy to install and use, and because it is a pure Python package, it should run wherever Python runs.
One limitation is that compressed pixel data (e.g. JPEG) can only be altered in an intelligent way if decompressing it first. Once decompressed, it can be altered and written back to a DICOM file the same way as initially uncompressed data.
pydicom has an MIT-based license.
See the installation guide.
Once installed, the package can be imported at a Python command line or used
in your own Python program with
See the examples directory
for both kinds of uses. Also see the User Guide
for more details of how to use the package.
New versions, major bug fixes, etc. will also be announced through the group.
To start learning how to use pydicom, see the pydicom User Guide.