How to Upload¶
Uploading DICOM files using our Python SDK is a straightforward process that involves three main steps:
starting the upload
uploading the files
completing the upload.
You can choose to upload files one by one or use a higher-level function to upload all files in a directory. Below, we outline these steps and provide example code to help you get started.
Upload All Files in a Directory¶
To simplify the process, you can use the upload_all_files_in_dir()
method, which will walk through all files and
subdirectories within a specified directory and upload each file.
import os
from icometrix_sdk import IcometrixApi
from icometrix_sdk.models.upload_entity import StartUploadDto
PROJECT_ID = "uuid"
DICOM_DIR_PATH = "<dir_path>"
if __name__ == '__main__':
os.environ["API_HOST"] = "https://icobrain-{region}.icometrix.com"
# Initialize the icometrix API
ico_api = IcometrixApi()
# Get the project, to make sure it's there (will throw a 404 in case the project is not found)
project = ico_api.projects.get_one_by_id(PROJECT_ID)
# Start an upload
data = StartUploadDto(icobrain_report_type="icobrain_ms")
upload = ico_api.uploads.start_upload(PROJECT_ID, data)
# Will walk through all files/subdirectories and upload all files
ico_api.uploads.upload_all_files_in_dir(upload.uri, DICOM_DIR_PATH)
# Once all files have been uploaded, signal that they are all there and start the import/processing
upload = ico_api.uploads.complete_upload(upload.uri)
Upload Files Individually¶
If you prefer to upload files one by one, you can use the upload_file method. This method requires the upload URI and the file path for each file you wish to upload.
ico_api.uploads.upload_dicom_path(upload.uri, dicom_path)