#dicom #command #index #file #archive #dataset #exploring

app medicom_tools

A collection of command-line tools for exploring DICOM, developed as examples for using the medicom crate

1 unstable release

0.5.0 Jan 2, 2025

#253 in Command line utilities

Download history 137/week @ 2024-12-28 30/week @ 2025-01-04

167 downloads per month

Apache-2.0

3MB
67K SLoC

medicom_tools

Command-line tools for exploring DICOM, built using the medicom library crate.

$ ./medicom_tools
Explore DICOM

Usage: medicom_tools <COMMAND>

Commands:
  print    Parses a single file and prints the DICOM elements to stdout
  image    Encodes PixelData into a standard image format
  browse   Browse a DICOM dataset in a text-based user interface
  index    Manage a database index of DICOM on disk
  archive  Archives DICOM datasets from a source folder into a destination folder
  scp      Starts an SCP service
  scu      Issue commands as an SCU
  help     Print this message or the help of the given subcommand(s)

Options:
  -h, --help  Print help

Print

$ ./medicom_tools help print
Parses a single file and prints the DICOM elements to stdout

Usage: medicom_tools print <FILE>

Arguments:
  <FILE>  The file to process as a DICOM dataset

Options:
  -h, --help  Print help

Browse

$ ./medicom_tools help browse
Browse a DICOM dataset in a text-based user interface

Usage: medicom_tools browse <FILE>

Arguments:
  <FILE>  The file to process as a DICOM dataset

Options:
  -h, --help  Print help

Image

$ ./medicom_tools help image
Encodes PixelData into a standard image format

Usage: medicom_tools image <FILE> <OUTPUT>

Arguments:
  <FILE>    The DICOM file to extract image data from
  <OUTPUT>  The output file to save the encoded image

Options:
  -h, --help  Print help

Index

$ ./medicom_tools help index
Manage a database index of DICOM on disk.

Recursively scans a folder for DICOM datasets, indexing them into a database.

Usage: medicom_tools index --db <DB> <COMMAND>

Commands:
  scan    Recursively scans a folder for DICOM datasets, indexing them into a database
  verify  Verify records in the database reference valid files on-disk
  help    Print this message or the help of the given subcommand(s)

Options:
  -d, --db <DB>
          The db URI of the index

  -h, --help
          Print help (see a summary with '-h')

Archive

$ ./medicom_tools help archive
Archives DICOM datasets from a source folder into a destination folder.

The source folder is assumed to be unstructured whereas the DICOM datasets will be copied into the destination folder in a consistent structure: - One series per folder - Each DICOM file will be named in the format `[SOP_UID].dcm`

Usage: medicom_tools archive <SOURCE> <DESTINATION>

Arguments:
  <SOURCE>
          The source folder of DICOM datasets to process

  <DESTINATION>
          The destination folder to archive datasets into

Options:
  -h, --help
          Print help (see a summary with '-h')

SCP

$ ./medicom_tools help scp
Starts an SCP service

Usage: medicom_tools scp [OPTIONS] --host <HOST> --aetitle <AETITLE> --max-assoc <MAX_ASSOC>

Options:
  -h, --host <HOST>
          The host/port to bind the service on

  -a, --aetitle <AETITLE>
          The AE Title to run as

  -m, --max-pdu-size <MAX_PDU_SIZE>
          The maximum PDU size to receive.

          Size is specified in bytes and should be no more than `u32::MAX`. If not specified then no maximum is configured.

  -m, --max-assoc <MAX_ASSOC>
          The maximum number of concurrent associations

  -d, --db <DB>
          The database URL for resolving DIMSE queries.

          If not specified then Query/Retrieve will not return results, and Store will not persist received series.

  -a, --accept-aet <ACCEPT_AET>
          Specifies an accepted AE Title for associations. Can be specified multiple times.

          The format for each accepted AE Title is `key=val` where `key` is a valid AE Title such as `MY_AE`, and `val` is the IP + port such as `127.0.0.1:4001`.

          If no accepted AE Titles are specified then all AE Titles are accepted, but cannot be connected to, such as for handling C-MOVE requests.

  -h, --help
          Print help (see a summary with '-h')

SCU

$ ./medicom_tools help scu
Issue commands as an SCU

Usage: medicom_tools scu [OPTIONS] --host <HOST> --my-ae <MY_AE> --host-ae <HOST_AE> <COMMAND>

Commands:
  echo   Issue a C-ECHO command
  find   Issue a C-FIND command
  store  Issue a C-STORE command
  move   Issue a C-MOVE command
  get    Issue a C-GET command
  help   Print this message or the help of the given subcommand(s)

Options:
  -h, --host <HOST>
          The host/port to connect to

  -m, --my-ae <MY_AE>
          The AE Title to represent this SCU

  -h, --host-ae <HOST_AE>
          The target AE Title on the host

  -m, --max-pdu-size <MAX_PDU_SIZE>
          The maximum PDU size to receive.

          Size is specified in bytes and should be no more than `u32::MAX`. If not specified then no maximum is configured.

  -h, --help
          Print help (see a summary with '-h')

Dependencies

~15–30MB
~548K SLoC