kkonganti@1: #!/usr/bin/env python kkonganti@1: kkonganti@1: import os kkonganti@1: import sys kkonganti@1: from textwrap import dedent kkonganti@1: kkonganti@1: import yaml kkonganti@1: kkonganti@1: kkonganti@1: def main(): kkonganti@1: """ kkonganti@1: Takes a tab-delimited text file with a mandatory header kkonganti@1: column and generates an HTML table. kkonganti@1: """ kkonganti@1: kkonganti@1: args = sys.argv kkonganti@1: if len(args) < 2 or len(args) >= 4: kkonganti@1: print( kkonganti@1: f"\nAt least one argument specifying the *.tblsum file is required.\n" kkonganti@1: + "No more than 2 command-line arguments should be passed.\n" kkonganti@1: ) kkonganti@1: exit(1) kkonganti@1: kkonganti@1: table_sum_on = str(args[1]).lower() kkonganti@1: cell_colors = f"{table_sum_on}.cellcolors.yml" kkonganti@1: kkonganti@1: if len(args) == 3: kkonganti@1: description = str(args[2]) kkonganti@1: else: kkonganti@1: description = "The results table shown here is a collection from all samples." kkonganti@1: kkonganti@1: if os.path.exists(cell_colors) and os.path.getsize(cell_colors) > 0: kkonganti@1: with open(cell_colors, "r") as cc_yml: kkonganti@1: cell_colors = yaml.safe_load(cc_yml) kkonganti@1: else: kkonganti@1: cell_colors = dict() kkonganti@1: kkonganti@1: with open(f"{table_sum_on}.tblsum.txt", "r") as tbl: kkonganti@1: header = tbl.readline() kkonganti@1: header_cols = header.strip().split("\t") kkonganti@1: kkonganti@1: html = [ kkonganti@1: dedent( kkonganti@1: f""" kkonganti@1:
kkonganti@1: kkonganti@1: kkonganti@1: kkonganti@1: """ kkonganti@1: ) kkonganti@1: ] kkonganti@1: kkonganti@1: for header_col in header_cols: kkonganti@1: html.append( kkonganti@1: dedent( kkonganti@1: f""" kkonganti@1: """ kkonganti@1: ) kkonganti@1: ) kkonganti@1: kkonganti@1: html.append( kkonganti@1: dedent( kkonganti@1: """ kkonganti@1: kkonganti@1: kkonganti@1: """ kkonganti@1: ) kkonganti@1: ) kkonganti@1: kkonganti@1: for row in tbl: kkonganti@1: html.append("\n") kkonganti@1: data_cols = row.strip().split("\t") kkonganti@1: if len(header_cols) != len(data_cols): kkonganti@1: print( kkonganti@1: f"\nWARN: Number of header columns ({len(header_cols)}) and data " kkonganti@1: + f"columns ({len(data_cols)}) are not equal!\nWill append empty columns!\n" kkonganti@1: ) kkonganti@1: if len(header_cols) > len(data_cols): kkonganti@1: data_cols += (len(header_cols) - len(data_cols)) * " " kkonganti@1: print(len(data_cols)) kkonganti@1: else: kkonganti@1: header_cols += (len(data_cols) - len(header_cols)) * " " kkonganti@1: kkonganti@1: html.append( kkonganti@1: dedent( kkonganti@1: f""" kkonganti@1: kkonganti@1: """ kkonganti@1: ) kkonganti@1: ) kkonganti@1: kkonganti@1: for data_col in data_cols[1:]: kkonganti@1: data_col_w_color = f""" kkonganti@1: """ kkonganti@1: if ( kkonganti@1: table_sum_on in cell_colors.keys() kkonganti@1: and data_col in cell_colors[table_sum_on].keys() kkonganti@1: ): kkonganti@1: data_col_w_color = f""" kkonganti@1: """ kkonganti@1: html.append(dedent(data_col_w_color)) kkonganti@1: html.append("\n") kkonganti@1: html.append("\n") kkonganti@1: html.append("
{header_col}
{data_cols[0]}{data_col}{data_col}
\n") kkonganti@1: html.append("
\n") kkonganti@1: kkonganti@1: mqc_yaml = { kkonganti@1: "id": f"{table_sum_on.upper()}_collated_table", kkonganti@1: "section_name": f"{table_sum_on.upper()}", kkonganti@1: "section_href": f"https://github.com/CFSAN-Biostatistics/bettercallsal", kkonganti@1: "plot_type": "html", kkonganti@1: "description": f"{description}", kkonganti@1: "data": ("").join(html), kkonganti@1: } kkonganti@1: kkonganti@1: with open(f"{table_sum_on.lower()}_mqc.yml", "w") as html_mqc: kkonganti@1: yaml.dump(mqc_yaml, html_mqc, default_flow_style=False) kkonganti@1: kkonganti@1: kkonganti@1: if __name__ == "__main__": kkonganti@1: main()