Mercurial > hg > orthanc-book
view Sphinx/source/plugins/python/excel.py @ 1033:f3f320632887
merge
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 02 Feb 2024 16:37:54 +0100 |
parents | 600da1bb6acd |
children |
line wrap: on
line source
import io import json import orthanc import xlwt def CreateExcelReport(output, uri, **request): if request['method'] != 'GET' : output.SendMethodNotAllowed('GET') else: # Create an Excel writer excel = xlwt.Workbook() sheet = excel.add_sheet('Studies') # Loop over the studies stored in Orthanc row = 0 studies = orthanc.RestApiGet('/studies?expand') for study in json.loads(studies): sheet.write(row, 0, study['PatientMainDicomTags'].get('PatientID')) sheet.write(row, 1, study['PatientMainDicomTags'].get('PatientName')) sheet.write(row, 2, study['MainDicomTags'].get('StudyDescription')) row += 1 # Serialize the Excel workbook to bytes, and return it to the caller b = io.BytesIO() excel.save(b) output.AnswerBuffer(b.getvalue(), 'application/vnd.ms-excel') orthanc.RegisterRestCallback('/report.xls', CreateExcelReport)