From 8b5a627111edc76ea92ae9be5e36c0c42d75df40 Mon Sep 17 00:00:00 2001 From: Rob Svirskas Date: Fri, 17 Nov 2023 10:58:53 -0500 Subject: [PATCH] Added slide checking --- bin/upload_precheck.py | 38 +++++++++++++++++++++++++++++++++----- 1 file changed, 33 insertions(+), 5 deletions(-) diff --git a/bin/upload_precheck.py b/bin/upload_precheck.py index 6912a94..65805ce 100644 --- a/bin/upload_precheck.py +++ b/bin/upload_precheck.py @@ -2,11 +2,12 @@ sample issues, optionally retagging documents. Documents will be tagged with the word "unreleased" as well as the ALPS release. ''' -__version__ = '0.0.2' +__version__ = '0.0.3' import argparse from operator import attrgetter import sys +from time import strftime import MySQLdb from tqdm import tqdm import jrc_common.jrc_common as JRC @@ -18,6 +19,7 @@ # Counters COUNT = {"images": 0, "found": 0, "updated": 0, "unreleased": 0} RELEASE = {} +SLIDES = [] def terminate_program(msg=None): ''' Terminate the program gracefully @@ -106,14 +108,37 @@ def check_image(row, non_public): if row['slideCode'] in non_public: release = non_public[row['slideCode']] if release: - LOGGER.warning("Sample %s (%s) is in non-public release %s", row['_id'], row['slideCode'], release) + LOGGER.warning("Sample %s (%s) is in non-public release %s", row['_id'], + row['slideCode'], release) else: LOGGER.warning("Sample %s (%s) is not prestaged", row['_id'], row['slideCode']) + SLIDES.append(row['slideCode']) tag_release(row, release) elif not row['publishedName']: LOGGER.error("No publishing name for %s", row['_id']) +def process_slide_codes(): + ''' Generate a report of slide codes with unreleased images + Keyword arguments: + None + Returns: + None + ''' + fname = strftime("%Y%m%dT%H%M%S") + "_precheck.tsv" + print(f"Some slide codes have images that may need to be retagged.\nCheck {fname}") + sql = "SELECT id,slide_code,workstation_sample_id,data_set,name,alps_release " \ + + "FROM image_data_mv WHERE slide_code=%s ORDER BY 2,3,4,5" + with open(fname, "w", encoding="ascii") as outf: + outf.write("ID\tSlide code\tSample\tData set\tALPS release\tImage name\n") + for scode in SLIDES: + DB['sage']['cursor'].execute(sql, (scode,)) + rows = DB['sage']['cursor'].fetchall() + for row in rows: + outf.write(f"{row['id']}\t{row['slide_code']}\t{row['workstation_sample_id']}\t" \ + + f"{row['data_set']}\t{row['alps_release']}\t{row['name']}\n") + + def perform_checks(): ''' Check all images for a given library/version Keyword arguments: @@ -132,7 +157,8 @@ def perform_checks(): if not count: terminate_program(f"There are no processed tags for version {ARG.VERSION} in {ARG.LIBRARY}") print(f"Images in {ARG.LIBRARY} {ARG.VERSION}: {count}") - sql = "SELECT DISTINCT slide_code,alps_release FROM image_data_mv WHERE alps_release IS NULL or alps_release IN (%s)" + sql = "SELECT DISTINCT slide_code,alps_release FROM image_data_mv WHERE display=1 AND " \ + + "alps_release IS NULL OR alps_release IN (%s)" if ARG.RAW: non_public.append('Split-GAL4 Omnibus Broad') sql = sql % ('"' + '","'.join(non_public) + '"',) @@ -151,8 +177,10 @@ def perform_checks(): if COUNT['found']: print(f"Images retagged: {COUNT['updated']}") print(f"Unreleased: {COUNT['unreleased']}") - for rel in RELEASE: - print(f"{rel}: {RELEASE[rel]}") + for key, val in RELEASE.items(): + print(f"{key}: {val}") + if SLIDES: + process_slide_codes() if __name__ == '__main__':